题目描述 对于一个数字字符串,如果它满足偶数下标处的数字为偶数且奇数下标处的数字为质数(下标从 0 开始,从左往右依次增大),我们称这它为“好数字”。 比如:"2582" 是“好数字”,因为偶数下标处的数字(下标为 0 的数字为 2、下标为 2 的数字为 8)是偶数,奇数下标处的数字(下标为 1 的数字为 5、下标为 3 的数字为 2)为质数。 但 "3245" 不是“好数字”,因为 3 在偶数下标处但不是偶数。 给你一个整数 n,请你返回长度为 n 且为“好数字”的数字字符串的个数。 由于答案可能会很大,请你将它对 10^9+7 取余后返回 。 注:一个数字字符串是指每一位都由 0 到 9 组成的字符串,且可能包含前导 0 。 输入描述 一个正整数,表示数字字符串的长度 n。 输出描述 一个正整数,表示最终的结果。 样例1 输入 1 输出 5 样例2 输入 5 输出 2000 样例3 输入 50 输出 564908303 提示 对于 100% 的数据,1≤n≤10^9。 请用C++语言完成
```cpp #include <iostream> using namespace std; const int MOD = 1e9 + 7; long long fast_pow(long long base, long long exp) { long long res = 1; while (exp > 0) { if (exp % 2 == 1) { res = (res * base) % MOD; } base = (base * base) % MOD; exp /= 2; } return res; } int countGoodNumbers(long long n) { long long even_pos = (n + 1) / 2; // 偶数位的个数 long long odd_pos = n / 2; // 奇数位的个数 long long even_choices = 5; // 偶数位可选数字:0,2,4,6,8 long long odd_choices = 4; // 奇数位可选数字:2,3,5,7 long long res = (fast_pow(even_choices, even_pos) * fast_pow(odd_choices, odd_pos)) % MOD; return res; } int main() { long long n; cin >> n; cout << countGoodNumbers(n) << endl; return 0; } ``` 代码解释: 1. 偶数位(下标0,2,4...)必须为偶数(0,2,4,6,8),共5种选择 2. 奇数位(下标1,3,5...)必须为质数(2,3,5,7),共4种选择 3. 总可能性数为5^even_pos * 4^odd_pos,其中even_pos和odd_pos分别表示偶数位和奇数位的数量 4. 使用快速幂算法计算大数幂次,避免超时 5. 结果对1e9+7取模 三条额外需要注意的逻辑点: - 偶数位和奇数位的数量计算需要考虑n的奇偶性 - 快速幂算法的时间复杂度是O(log n),适合处理大指数 - 模运算要在每次乘法后进行,防止中间结果溢出 [2025-07-21 17:46:17 | AI写代码神器 | 457点数解答]
- [DeepSeek] 题目描述 对于一个数字字符串,如果它满足偶数下标处的数字为偶数且奇数下标处的数字为质数(下标从 0 开始,从左往右依次增大),我们称这它为“好数字”。 比如:"2582" 是“好数字”,因为偶数下标处的数字(下标为 0 的数字为 2、下标为 2 的数字为 8)是偶数,奇数下标处的数字(下标为 1 的数字为 5、下标为 3 的数字为 2)为质数。 但 "3245" 不是“好数字”,因为 3 在偶数下标处但不是偶数。 给你一个整数 n,请你返回长度为 n 且为“好数字”的数字字符串的个数。 由于答案可能会很大,请你将它对 10^9+7 取余后返回 。 注:一个数字字符串是指每一位都由 0 到 9 组成的字符串,且可能包含前导 0 。 输入描述 一个正整数,表示数字字符串的长度 n。 输出描述 一个正整数,表示最终的结果。 样例1 输入 1 输出 5 样例2 输入 5 输出 2000 样例3 输入 50 输出 564908303 提示 对于 100% 的数据,1≤n≤10^9。 请用C++语言完成(457点数解答 | 2025-07-21 17:46:17)128
- [DeepSeek] 题目描述 对于一个数字字符串,如果它满足偶数下标处的数字为偶数且奇数下标处的数字为质数(下标从 0 开始,从左往右依次增大),我们称这它为“好数字”。 比如:"2582" 是“好数字”,因为偶数下标处的数字(下标为 0 的数字为 2、下标为 2 的数字为 8)是偶数,奇数下标处的数字(下标为 1 的数字为 5、下标为 3 的数字为 2)为质数。 但 "3245" 不是“好数字”,因为 3 在偶数下标处但不是偶数。 给你一个整数 n,请你返回长度为 n 且为“好数字”的数字字符串的个数。 由于答案可能会很大,请你将它对 10^9+7 取余后返回 。 注:一个数字字符串是指每一位都由 0 到 9 组成的字符串,且可能包含前导 0 。 请用C++语言以及快速幂完成 输入描述 一个正整数,表示数字字符串的长度 n。 输出描述 一个正整数,表示最终的结果。 样例1 输入 1 输出 5 样例2 输入 5 输出 2000 样例3 输入 50 输出 564908303 提示 对于 100% 的数据,1≤n≤10^9。(488点数解答 | 2025-07-21 17:50:31)155
- [字节豆包] 题目描述 给定m行n列的图像各像素点的灰度值,要求用如下方法对其进行模糊化处理: 1.四周最外侧的像素点灰度值不变; 2.中间各像素点新灰度值为该像素点及其上下左右相邻四个像素点原灰度值的平均值(四舍五入)。 输入格式 第一行包含两个整数n和m,表示图像包含像素点的行数和列数。1<=n<=100,1<=m<=100。 接下来n行,每行m个整数,表示图像的每个像素点灰度。相邻两个整数之间用单个空格隔开,每个元素均在0~255之间。 输出格式 m行,每行n个整数,为模糊处理后的图像。相邻两个整数之间用单个空格隔开。 输入样例1 4 5 100 0 100 0 50 50 100 200 0 0 50 50 100 100 200 100 100 50 50 100 输出样例1 100 0 100 0 50 50 80 100 60 0 50 80 100 90 200 100 100 50 50 100 用c++语言 (670点数解答 | 2025-11-10 18:55:33)39
- [字节豆包] 题目描述 给定m行n列的图像各像素点的灰度值,要求用如下方法对其进行模糊化处理: 1.四周最外侧的像素点灰度值不变; 2.中间各像素点新灰度值为该像素点及其上下左右相邻四个像素点原灰度值的平均值(四舍五入)。 输入格式 第一行包含两个整数n和m,表示图像包含像素点的行数和列数。1<=n<=100,1<=m<=100。 接下来n行,每行m个整数,表示图像的每个像素点灰度。相邻两个整数之间用单个空格隔开,每个元素均在0~255之间。 输出格式 m行,每行n个整数,为模糊处理后的图像。相邻两个整数之间用单个空格隔开。 输入样例 4 5 100 0 100 0 50 50 100 200 0 0 50 50 100 100 200 100 100 50 50 100 输出样例 100 0 100 0 50 50 80 100 60 0 50 80 100 90 200 100 100 50 50 100 说明/提示 用c++(655点数解答 | 2025-12-01 14:24:01)15
- [字节豆包] 题目描述 幼儿园里有 n 个小朋友,每个小朋友有一个学号。 老师要求:学号是奇数的小朋友站一排,学号是偶数的小朋友站一排。 提示: 奇数:个位为 1,3,5,7,9 的数字,满足除以 2 的余数为 1。 偶数:个位为 0,2,4,6,8 的数字,满足除以 2 的余数为 0。 输入格式 共两行,第一行一个数字 n,表示有 n 个小朋友。 第二行共 n 个数字,其中第 i 个数字 ai表示第 i 个小朋友的学号。 输出格式 共两行,第一行一些数字,表示学号为奇数的小朋友的学号,按照输入的顺序输出。 即,如果一个数字输入的时候在前,那么输出的时候也应当在前。 第二行一些数字,表示学号为偶数的小朋友的学号,按照输入的顺序输出。 保证小朋友的学号既有奇数,又有偶数。 输入输出样例 输入 #1 5 1 2 3 4 5 输出 #1 1 3 5 2 4 输入 #2 5 5 2 3 1 4 输出 #2 5 3 1 2 4 说明/提示 对于 20% 的数据,n=2; 对于 40% 的数据,满足 n≤100; 对于另外 20% 的数据,满足 ai=(406点数解答 | 2025-11-26 19:39:05)16
- [字节豆包] 三倍子串 内存限制: 256 Mb时间限制: 1000 ms 题目描述 给定一个十进制正整数 n n,请问可以从 n n 中截取多少种不同的子串,使得子串构成的数字是 3 3 的倍数。 例如:当 n = 1234 n=1234 时,有且仅有 3 3, 12 12, 123 123, 234 234 这四个子串是 3 3 的倍数。 输入格式 单个整数:表示输入的数字 n n 输出格式 单个整数:表示 3 3 的倍数的子串数量。 数据范围 对于 20 % 20% 的数据, 1 ≤ n ≤ 1 0 9 1≤n≤10 9 ; 对于 50 % 50% 的数据, 1 ≤ n ≤ 1 0 100 1≤n≤10 100 ; 对于 70 % 70% 的数据, 1 ≤ n ≤ 1 0 1000 1≤n≤10 1000 ; 对于 100 % 100% 的数据, 1 ≤ n ≤ 1 0 100000 1≤n≤10 100000 样例数据 输入: 95764 输出: 6 说明: 子串6,9,57,576,957,9576是3的倍数 输入: 1111 输出: 2 说(486点数解答 | 2025-08-29 11:52:55)143
- [字节豆包] 题目描述 扶苏来到了一个迷宫,这个迷宫是一个 n 行 m 列的数字矩阵,第 i 行第 j 列写有 一个数字 ai,j。保证 1≤ai,j≤4。 扶苏会在这个迷宫的某一个位置。假设她当前在迷宫的第 i 行第 j 列: 如果 ai,j=1,则她会向上移动一行,即 i 减小 1。 如果 ai,j=2,则她会向下移动一行,即 i 增大 1。 如果 ai,j=3,则她会向左移动一列,即 j 减小 1。 如果 ai,j=4,则她会向右移动一列,即 j 增大 1。 初始时和每次移动到另一个格子后,她都会按上述的规则继续进行新的移动。 当她移动出迷宫,即到达第 0 行、第 0 列、第 n+1 行、第 m+1 列时,称她离开了 迷宫。 现在,你要回答 q 次询问,每次给定一个扶苏的初时位置,你要回答她在多少次移动 后会离开迷宫,或报告她永远不会离开迷宫。 输入格式 第一行是三个整数,表示迷宫的行数 n、列数 m 和询问数 q。 接下来 n 行,每行 m 个整数,表示矩阵 a。 接下来 q 行,每行两个整数 xi,yi,表示一次查询初时在第 xi行yi列时她离开迷宫需 要的步数。(819点数解答 | 2025-11-26 19:27:35)21
- [字节豆包] 题目描述 给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值。 输入格式 一行,为需要你计算的表达式,表达式中只包含数字、加法运算符 + 和乘法运算符 *,且没有括号,所有参与运算的数字均为0到231−1 之间的整数。 输入数据保证这一行只有 0*********+* 这 12 种字符。 输出格式 一个整数,表示这个表达式的值。 注意:当答案长度多于 4 位时,请只输出最后 4 位,前导 0 不输出。 输入输出样例 输入 #1 1+1*3+4 输出 #1 8 输入 #2 1+*********0*1 输出 #2 7891 输入 #3 1+1000000003*1 输出 #3 4 说明/提示 对于 30% 的数据,0≤ 表达式中加法运算符和乘法运算符的总数 ≤100。 对于 80% 的数据,0≤ 表达式中加法运算符和乘法运算符的总数 ≤1000。 对于 100% 的数据,0≤ 表达式中加法运算符和乘法运算符的总数 ≤100000 用c++语言(730点数解答 | 2025-11-26 20:12:36)16
- [字节豆包] 题目描述 给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值。 输入格式 一行,为需要你计算的表达式,表达式中只包含数字、加法运算符 + 和乘法运算符 *,且没有括号,所有参与运算的数字均为0到231−1 之间的整数。 输入数据保证这一行只有 0*********+* 这 12 种字符。 输出格式 一个整数,表示这个表达式的值。 注意:当答案长度多于 4 位时,请只输出最后 4 位,前导 0 不输出。 输入输出样例 输入 #1 1+1*3+4 输出 #1 8 输入 #2 1+*********0*1 输出 #2 7891 输入 #3 1+1000000003*1 输出 #3 4 说明/提示 对于 30% 的数据,0≤ 表达式中加法运算符和乘法运算符的总数 ≤100。 对于 80% 的数据,0≤ 表达式中加法运算符和乘法运算符的总数 ≤1000。 对于 100% 的数据,0≤ 表达式中加法运算符和乘法运算符的总数 ≤100000。 用c++语言,用简单方法(437点数解答 | 2025-11-26 20:13:21)19
- [DeepSeek] c++ 给定一个序列 (a_1, a_2, ..., a_n), 定义序列中的一个递增三元组是指三个下标 i, j, k 对应的三个元素 a_i, a_j, a_k,这三个元素满足 a_i < a_j < a_k。 例如序列 (1, 1, 4, 3, 2, 4) 有以下 4 个递增三元组: 1. 下标 1, 4, 6 对应的 1, 3, 4; 2. 下标 1, 5, 6 对应的 1, 2, 4; 3. 下标 2, 4, 6 对应的 1, 3, 4; 4. 下标 2, 5, 6 对应的 1, 2, 4。 注意,可能有下标不同但对应数值相同的三元组,他们应当算成不同的三元组。 给定序列,请问序列中一共有多少个不同的递增三元组。 输入格式 输入第一行包含一个整数 n,表示序列的长度。 第二行包含 n 个整数 a_1, a_2, ..., a_n,表示给定的序列。 输出格式 输出一行,包含一个整数,表示序列中的递增三元组数量。请注意答案可能很大,可能超过 32 位二进制整数的范围,建议使用 64 位二进制整数。 样例输入 6 1 1 4 3 2 4(742点数解答 | 2025-02-25 18:35:56)223
- [DeepSeek] c++ 给定一个序列 (a_1, a_2, ..., a_n), 定义序列中的一个递增三元组是指三个下标 i, j, k 对应的三个元素 a_i, a_j, a_k,这三个元素满足 a_i < a_j < a_k。 例如序列 (1, 1, 4, 3, 2, 4) 有以下 4 个递增三元组: 1. 下标 1, 4, 6 对应的 1, 3, 4; 2. 下标 1, 5, 6 对应的 1, 2, 4; 3. 下标 2, 4, 6 对应的 1, 3, 4; 4. 下标 2, 5, 6 对应的 1, 2, 4。 注意,可能有下标不同但对应数值相同的三元组,他们应当算成不同的三元组。 给定序列,请问序列中一共有多少个不同的递增三元组。 输入格式 输入第一行包含一个整数 n,表示序列的长度。 第二行包含 n 个整数 a_1, a_2, ..., a_n,表示给定的序列。 输出格式 输出一行,包含一个整数,表示序列中的递增三元组数量。请注意答案可能很大,可能超过 32 位二进制整数的范围,建议使用 64 位二进制整数。 样例输入 6 1 1 4 3 2 4(631点数解答 | 2025-02-25 18:40:05)164
- [字节豆包] 请你补全代码,把数组a的所有元素都赋值为100。 输入: 无 输出: 共二十行,每行一个整数,为数组中的每个数。 输入样例: 无 输出样例: 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100 100#include <iostream> using namespace std; int main() { int a[20]; for ( ) { } for (int i = 0; i < 20; i++) { cout << a[i] << endl; } return 0; }(164点数解答 | 2025-11-01 19:14:57)37