2023-12-13:用go语言,密码是一串长度为n的小写字母,一则关于密码的线索纸条,

首先将字母a到z编号为0到25编号,

纸条上共有n个整数ai,其中a1表示密码里第一个字母的编号,

若i>1的话就表示第i个字母和第i-1个字母编号的差值,

例如,a2就代表密码中第1个字母和第2个字母编号的差值,

若密码是acb,那么纸条上的数字就是[5, 2, 1],

a b c d e f

0 1 2 3 4 5

返回可能的密码的个数,由于结果可能很大,

输出对1000000007取模的结果。

1 <= n <= 10^5,

0 <= ai <= 25。

来自字节。

答案2023-12-13:

灵捷3.5

大体过程如下:

算法一(ways1):

1.定义函数ways1,传入一个整数数组arr作为参数。

2.在process1函数中,传入当前索引i和前一个字母的编号pre作为参数。

3.如果pre小于0或大于25,则返回0;否则,进入下一步。

4.若当前索引i等于数组长度,则说明已经遍历完所有字母,返回1。

5.否则,定义变量ans初始化为0。

6.递归调用process1函数,传入i+1和pre-arr[i]作为参数,并将结果累加到ans上。

7.递归调用process1函数,传入i+1和pre+arr[i]作为参数,并将结果累加到ans上。

8.返回ans作为结果。

算法二(ways2):

1.定义函数ways2,传入一个整数数组arr作为参数。

2.初始化变量mod为1000000007和n为数组长度。

3.创建二维切片dp,大小为(n+1)×26,用于存储动态规划的结果。其中dp[i][j]表示考虑第i个位置时,以j号字母结尾的可能密码的个数。

4.将最后一行dp[n][j]全部初始化为1,表示在最后一个位置时,每个字母都是合法的密码结尾位置。

5.倒序遍历数组arr中的元素:

5.1.对于每个字母对应的编号j,遍历0到25:

5.1.1.如果j-arr[i]大于等于0,则将dp[i][j]的值更新为dp[i+1][j-arr[i]]。

5.1.2.如果j+arr[i]小于26,则将dp[i][j]的值与dp[i+1][j+arr[i]]相加,并对mod取模。

6.返回dp[1][arr[0]]作为结果。

算法一的时间复杂度是O(2^n),空间复杂度是O(n)。

算法二的时间复杂度是O(n),空间复杂度是O(n)。

go完整代码如下:

package main

import "fmt"

func ways1(arr []int) int {
return process1(arr, 1, arr[0])
} func process1(arr []int, i, pre int) int {
if pre < 0 || pre > 25 {
return 0
} else {
if i == len(arr) {
return 1
} else {
ans := 0
ans += process1(arr, i+1, pre-arr[i])
ans += process1(arr, i+1, pre+arr[i]) return ans
}
}
} func ways2(arr []int) int {
mod := 1000000007
n := len(arr)
dp := make([][]int, n+1)
for i := 0; i <= n; i++ {
dp[i] = make([]int, 26)
} for j := 0; j < 26; j++ {
dp[n][j] = 1
} for i := n - 1; i >= 1; i-- {
for j := 0; j < 26; j++ {
if j-arr[i] >= 0 {
dp[i][j] = dp[i+1][j-arr[i]]
}
if j+arr[i] < 26 {
dp[i][j] = (dp[i][j] + dp[i+1][j+arr[i]]) % mod
}
}
} return dp[1][arr[0]]
} func main() {
arr := []int{5, 2, 1}
result1 := ways1(arr)
result2 := ways2(arr) fmt.Println("Result using ways1:", result1)
fmt.Println("Result using ways2:", result2)
}

c++完整代码如下:

#include <iostream>
#include <vector> int process1(std::vector<int>& arr, int i, int pre) {
if (pre < 0 || pre > 25) {
return 0;
}
else {
if (i == arr.size()) {
return 1;
}
else {
int ans = 0;
ans += process1(arr, i + 1, pre - arr[i]);
ans += process1(arr, i + 1, pre + arr[i]); return ans;
}
}
} int ways1(std::vector<int>& arr) {
return process1(arr, 1, arr[0]);
} int ways2(std::vector<int>& arr) {
const int MOD = 1000000007;
int n = arr.size();
std::vector<std::vector<int>> dp(n + 1, std::vector<int>(26)); for (int j = 0; j < 26; ++j) {
dp[n][j] = 1;
} for (int i = n - 1; i >= 1; --i) {
for (int j = 0; j < 26; ++j) {
if (j - arr[i] >= 0) {
dp[i][j] = dp[i + 1][j - arr[i]];
}
if (j + arr[i] < 26) {
dp[i][j] = (dp[i][j] + dp[i + 1][j + arr[i]]) % MOD;
}
}
} return dp[1][arr[0]];
} int main() {
std::vector<int> arr{ 5, 2, 1 };
int result1 = ways1(arr);
int result2 = ways2(arr); std::cout << "Result using ways1: " << result1 << std::endl;
std::cout << "Result using ways2: " << result2 << std::endl; return 0;
}

c完整代码如下:

#include <stdio.h>
#include <stdlib.h> int process1(int* arr, int i, int pre, int len) {
if (pre < 0 || pre > 25) {
return 0;
}
else {
if (i == len) {
return 1;
}
else {
int ans = 0;
ans += process1(arr, i + 1, pre - arr[i], len);
ans += process1(arr, i + 1, pre + arr[i], len); return ans;
}
}
} int ways1(int* arr, int len) {
return process1(arr, 1, arr[0], len);
} int ways2(int* arr, int len) {
const int MOD = 1000000007;
int n = len;
int** dp = (int**)malloc((n + 1) * sizeof(int*)); for (int i = 0; i <= n; ++i) {
dp[i] = (int*)malloc(26 * sizeof(int));
} for (int j = 0; j < 26; ++j) {
dp[n][j] = 1;
} for (int i = n - 1; i >= 1; --i) {
for (int j = 0; j < 26; ++j) {
if (j - arr[i] >= 0) {
dp[i][j] = dp[i + 1][j - arr[i]];
}
if (j + arr[i] < 26) {
dp[i][j] = (dp[i][j] + dp[i + 1][j + arr[i]]) % MOD;
}
}
} int result = dp[1][arr[0]]; for (int i = 0; i <= n; ++i) {
free(dp[i]);
} free(dp); return result;
} int main() {
int arr[] = { 5, 2, 1 };
int len = sizeof(arr) / sizeof(arr[0]); int result1 = ways1(arr, len);
int result2 = ways2(arr, len); printf("Result using ways1: %d\n", result1);
printf("Result using ways2: %d\n", result2); return 0;
}

2023-12-13:用go语言,密码是一串长度为n的小写字母,一则关于密码的线索纸条, 首先将字母a到z编号为0到25编号, 纸条上共有n个整数ai,其中a1表示密码里第一个字母的编号, 若i>1的的更多相关文章

  1. 12天学好C语言——记录我的C语言学习之路(Day 12)

    12天学好C语言--记录我的C语言学习之路 Day 12: 进入最后一天的学习,用这样一个程序来综合考量指针和字符串的关系,写完这个程序,你对字符串和指针的理解应该就不错了. //输入一个字符串,内有 ...

  2. 12天学好C语言——记录我的C语言学习之路(Day 11)

    12天学好C语言--记录我的C语言学习之路 Day 11: 因为指针部分比较的难,所以我们花费的时间也是最长的,希望大家耐的住性子,多多理解,多多打代码.好了,废话不多说,来看第11天的学习. //编 ...

  3. 12天学好C语言——记录我的C语言学习之路(Day 8)

    12天学好C语言--记录我的C语言学习之路 Day 8: 从今天开始,我们获得了C语言中很有力的一个工具,那就是函数.函数的魅力不仅于此,一个程序到最后都是由众多函数组成的,我们一定要用好函数,用熟练 ...

  4. 12天学好C语言——记录我的C语言学习之路(Day 7)

    12天学好C语言--记录我的C语言学习之路 Day 7: 昨天进行了一天的数组学习,今天大家可以先写几个昨天的程序热热身,回顾回顾,然后今天第一个新程序也是关于数组的,比较难,准备好就开始啦! //输 ...

  5. 12天学好C语言——记录我的C语言学习之路(Day 2)

    12天学好C语言--记录我的C语言学习之路 Day 2: 我建议大家每一天学习之前都仅凭记忆去敲前一天敲过的最后一个程序,或者敲前一天你认为最难最长的一个程序,如果一晚上的睡眠之后不看书还能敲的出来, ...

  6. 输入一个字符串,内有数字和非数字字符。例如:a123x456 17960 302tab5876。将其中连续的数字作为一个整数,依次存放到一维数组a中,例如123放在a[0],456放在a[1]……统计共有多少个整数,并输出这些数。

    题目内容:输入一个字符串,内有数字和非数字字符.例如:a123x456 17960 302tab5876.将其中连续的数字作为一个整数,依次存放到一维数组a中,例如123放在a[0],456放在a[1 ...

  7. 12天学好C语言——记录我的C语言学习之路(Day 10)

    12天学好C语言--记录我的C语言学习之路 Day 10: 接着昨天的指针部分学习,有这么一个题目: //还是四个学生,四门成绩,只要有学生一门功课没及格就输出这个学生的所有成绩 /*//progra ...

  8. 12天学好C语言——记录我的C语言学习之路(Day 9)

    12天学好C语言--记录我的C语言学习之路 Day 9: 函数部分告一段落,但是我们并不是把函数完全放下,因为函数无处不在,我们今后的程序仍然会大量运用到函数 //转入指针部分的学习,了解指针是什么 ...

  9. 12天学好C语言——记录我的C语言学习之路(Day 3)

    12天学好C语言--记录我的C语言学习之路 Day 3: 不知不觉到了第三天的学习,我们前两天学习的东西很杂乱,各个方面都有学习.我觉得这不是不系统,也不是学的不扎实,这种学习对于初学者而言我认为是很 ...

  10. 12天学好C语言——记录我的C语言学习之路(Day 1)

    12天学好C语言--记录我的C语言学习之路 Day 1: 刚刚入门C语言,那么肯定要先把什么是C语言和大家讲清楚,那么大家看下面一段程序(program  1.1): /*//program 1.1 ...

随机推荐

  1. 干货分享:用ChatGPT调教批量出Midjourney咒语,出图效率Nice ,附资料。

    Prompts就是AI绘图的核心竞争力. 您是不是觉得用Midjourney生成的图不够完美? 又让ChatGPT去生成Prompt,然后效果还不理想? 其实ChatGPT你给他投喂资料后,经过调教的 ...

  2. WPF学习:Slider — 冒泡显示值

    想做一个下图所示的Slider,以冒泡的方式显示其Value值,该怎么做呢? 功能要求,当鼠标放在滑块上的时候,冒"泡"显示值:当滑块移动的时候,"泡"跟随移动 ...

  3. 开源.NetCore通用工具库Xmtool使用连载 - 图形验证码篇

    [Github源码] <上一篇> 介绍了Xmtool工具库中的Web操作类库,今天我们继续为大家介绍其中的图形验证码类库. 图形验证码是为了抵御恶意攻击出现的一种设计:例如用户登录.修改密 ...

  4. LeetCode买卖股票之一:基本套路(122)

    欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 关于<LeetCode买卖股票>系列 在L ...

  5. 「acmhdu - 6314」Matrix

    link. 首先将问题弱化为 1-d,我们待定容斥系数 \(f_i\),可以写出答案的式子:\(\sum\limits_{i=a}^nf_i\binom{n}{i}2^{n-i}\).解释就是,我们想 ...

  6. Solution -「YunoOI 2007」rfplca

    Description Link. Given is a rooted tree with the \(\sf1\)-th node as the root. The tree will be giv ...

  7. 爬虫系列——selenium

    文章目录 一 介绍 二 安装 三 基本使用 四 选择器 五 等待元素被加载 六 元素交互操作 七 其他 八 项目练习 一 介绍 selenium最初是一个自动化测试工具,而爬虫中使用它主要是为了解决r ...

  8. Spring扩展接口(2):BeanDefinitionRegistryPostProcessor

    在此系列文章中,我总结了Spring几乎所有的扩展接口,以及各个扩展点的使用场景.并整理出一个bean在spring中从被加载到最终初始化的所有可扩展点的顺序调用图.这样,我们也可以看到bean是如何 ...

  9. My 2022

    很久以前好像是想过要写这么一个东西的.然而时间已至却毫无思路,故拖延至今. 很充实的一年.但似乎是唯一除了 whk/OI 相关完全不知还能写些什么的一年呢.(笑) 本来想写些别的什么,又忽而发现所有想 ...

  10. CSP2021游记

    题外话 中午十二点半到了考场.没到时间不让进,恰巧发现 lhm 在对面饭店于是去讨论了一下上午 J 组的题,复习了线段树板子( 等到进考场坐好的时候已经两点半了,看考号本来以为我们同机房三个同学会坐一 ...