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

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

时间:2023-12-13 17:56:49浏览次数:35  
标签:pre arr int 纸条 密码 ans 编号 process1 dp

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;
}

在这里插入图片描述

标签:pre,arr,int,纸条,密码,ans,编号,process1,dp
From: https://www.cnblogs.com/moonfdd/p/17899615.html

相关文章

  • [CSP-S 2023] 密码锁
    [CSP-S2023]密码锁考场上我跟个\(somebody\)一样,一看就想:一眼乘法原理,乱搞写一下就出来了。当时我还算了一下暴力好像也不会超时,结果,每天在yz日以继日的颓废考试经验,我断定CSP-S是不会考这么\(!\)复杂的题目的,结果暴力出奇迹,就是枚举模拟。考试后,一看wc枚举,我断定我......
  • 苹果将推出全新iPhone安全模式:防止密码被盗
    据媒体报道,苹果公司将为iPhone推出一种新的安全模式,可以在小偷或其他攻击者知道用户的私人密码时保护用户。据了解,如果手机位于通常与其所有者无关的位置,并且开启了“被盗设备保护”功能,则该设备将需要苹果的FaceID面部识别以及用户执行敏感操作(例如查看存储密码或擦除手机)的密码......
  • spring使用druid多数据源yml密码加密
    1.依赖<!--Mysql驱动包--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.24</version></dependency><!--Druid--><dependency>......
  • MySQL 忘记密码解决方案
    数据库版本5.7.301配置文件中去掉认证编辑my.cnf服务配置文件 [mysqld]段段中加入skip-grant-tables语句2本地root账号免密登陆[root@mysql0006bin]#./mysql-uroot-pWelcometotheMySQLmonitor.Commandsendwith;or\g.YourMySQLconnectionidis3Serverversi......
  • vscode ssh 一直需要输入密码且最后显示连接失败
    参照这一篇执行就成功了,大佬很强很强。但是有几个点要注意的,我总结成下面几个步骤:先在本地用ssh连接,直到失败,查看日志上加锁的文件。日志在下面vscode这个界面找到。找到一条:[09:14:20.176]>Acquiringlockon/home/zhangyasheng/.vscode-server/bin/c3f126316369cd610563......
  • ubuntu的默认root密码
    Ubuntu默认是没有为root用户设置密码的。在Ubuntu系统中,root用户默认是锁定的,这意味着您无法直接作为root用户登录。但是,您可以通过以下方法访问root用户的权限:使用sudo:Ubuntu推荐使用sudo命令来执行需要管理员权限的操作。当您在命令前加上sudo并且输入您的普......
  • Oracle-修改数据库密码
    当Oracle数据库用户的密码过期时,你可以采取以下步骤来处理:1、连接到数据库:使用具有管理员权限的账户(比如SYS或SYSTEM用户)连接到Oracle数据库。查看过期用户:运行以下SQL查询语句查看已过期的用户列表:SELECTusernameFROMdba_usersWHEREaccount_status='EXPIRED......
  • 杂项与密码7
    misc1.jpg 先用工具看看 没有出现其他压缩包,但有文件。。搜搜 要手动分离 出来啦 2.bmp 没见过的文件尾 不需要改 哈?!! 3.文件分离 根据题意用winhex看看 没有。。分离文件 有文件 dd4这个文件。。有 4.文件属性 没有 题目说这个......
  • 修改Postgresql默认账号postgres的密码
    1.修改用户postgres的密码PostgreSQL数据库默认创建管理员账号:postgres;修改其密码,仅需一下三步:1、首先,登录PostgreSQLsudo-upostgrespsqlpostgres-p54322、然后,修改账号postgres的密码ALTERUSERpostgresWITHPASSWORD'Lpf65BsDhDNdaJmH';3、最后,退出pgsql客户端exi......
  • 装完Ubuntu后默认root用户的密码是多少?如何修改root密码
    1、Ubuntu的默认root密码是随机的,即每次开机都有一个新的root密码。可以在终端输入命令:sudopasswd然后输入当前用户的密码。2、终端会提示输入新的密码并确认,此时的密码就是root新密码。修改成功后,输入命令:suroot再输入新的密码就ok了。......