有n个灯( 1 ≤ 𝑛 ≤ 10 9 ),编号为1,2,……n,同时有n个人,依次对灯进行操作。 开始时,所有灯是关闭状态。 第1人操作:将所有灯打开 第2人操作:将2及2的倍数的灯,状态取反,即开状态变为关状态,其状态变为开状态。 第3人操作:将3及3倍数的灯状态取反。 …… 第i人操作:将i及i的倍数的灯状态取反(1≤i≤n),当所有操作完成之后,计算出所有开状态灯的编号之和。 例如:n=6, 0—关状态,1—开状态 开始 0 0 0 0 0 0 第1人操作之后:变成 1 1 1 1 1 1 第2人操作之后:变成 1 0 1 0 1 0 第3人操作之后:变成 1 0 0 0 1 1 第4人操作之后:变成 1 0 0 1 1 1 第5人操作之后:变成 1 0 0 1 0 1 第6人操作之后:变成 1 0 0 1 0 0 所有开状态灯编号之和为 1+4=5 输入 一个整数 𝑛 输出 一个整数,即操作后所有开状态的灯编号之和。 样例输入 复制 6 样例输出 复制 5 来源/分类 数论 筛法
这个问题是经典的“开关灯”问题。每个灯作的次数等于其编号的因数个数。 灯最终状态由操作次数的奇偶性决定:奇数次操作灯亮,偶数次操作灯灭。 一个数有奇数个因数当且仅当它是完全平方数。 亮灯的编号就是所有不超过 n 的完全平方数。 它们的和就是: \[ \sum_{k=1}^{\lfloor \sqrt{n} \rfloor} k^2 \] 代码实现: ```python n = int(input()) k = int(n 0.5) ans = sum(i * i for i in range(1, k + 1)) print(ans) ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 当 n 很大时(最大 1e9),直接遍历 1 到 n 会超时,必须用数学方法。 2. 计算平方根取整时,注意浮点数精度问题,可以用 int(n 0.5) 或 math.isqrt(n)(Python 3.8+)。 3. 求和时使用公式或循环,注意数据范围,Python 整数不会溢出,但其他语言可能需要使用 long long 类型。 [2026-01-18 12:41:43 | AI写代码神器 | 271点数解答]
相关提问
- [DeepSeek] 有n个灯( 1 ≤ 𝑛 ≤ 10 9 ),编号为1,2,……n,同时有n个人,依次对灯进行操作。 开始时,所有灯是关闭状态。 第1人操作:将所有灯打开 第2人操作:将2及2的倍数的灯,状态取反,即开状态变为关状态,其状态变为开状态。 第3人操作:将3及3倍数的灯状态取反。 …… 第i人操作:将i及i的倍数的灯状态取反(1≤i≤n),当所有操作完成之后,计算出所有开状态灯的编号之和。 例如:n=6, 0—关状态,1—开状态 开始 0 0 0 0 0 0 第1人操作之后:变成 1 1 1 1 1 1 第2人操作之后:变成 1 0 1 0 1 0 第3人操作之后:变成 1 0 0 0 1 1 第4人操作之后:变成 1 0 0 1 1 1 第5人操作之后:变成 1 0 0 1 0 1 第6人操作之后:变成 1 0 0 1 0 0 所有开状态灯编号之和为 1+4=5 输入 一个整数 𝑛 输出 一个整数,即操作后所有开状态的灯编号之和。 样例输入 复制 6 样例输出 复制 5 来源/分类 数论 筛法(271点数解答 | 2026-01-18 12:41:43)52
- [字节豆包] 题目描述 小明刚刚学习了三种整数编码方式:原码、反码、补码,并了解到计算机存储整数通常使用补码。但他总是觉得,生活中很少用到 2 31 − 1 2 31 −1 这么大的数,生活中常用的 0 ∼ 100 0∼100 这种数也同样需要用 4 4 个字节的补码表示,太浪费了些。 热爱学习的小明通过搜索,发现了一种正整数的变长编码方式。这种编码方式的规则如下: 对于给定的正整数,首先将其表达为二进制形式。例如, ( 0 ) { 10 } = ( 0 ) { 2 } (0) {10} =(0) {2} , ( 926 ) { 10 } = ( 1110011110 ) { 2 } (926) {10} =(1110011110) {2} 。 将二进制数从低位到高位切分成每组 7 7 bit,不足 7 7bit 的在高位用 0 0 填补。例如, ( 0 ) { 2 } (0) {2} 变为 0000000 0000000 的一组, ( 1110011110 ) { 2 } (1110011110) {2} 变为 001111(490点数解答 | 2026-01-02 19:51:12)21
- [字节豆包] 题目描述 Q老师在班级中管理着同学们的成绩。你需要帮助Q老师完成以下两项任务: 修改某个同学的成绩,需要给出学生编号 num (编号从 1 开始)和修改后的成绩 grade。 查看所有同学的成绩。 Q老师会给你所有同学的成绩,接下来会有若干操作,根据操作的类型来修改成绩或查看所有成绩。 输入格式 第一行输入整数 n,表示学生人数。 接下来输入 n 行,每行输入一个学生的成绩(整数)。 然后输入整数 m,表示接下来有 m 个操作。操作有两种: update 操作:修改某个学生的成绩,接下来输入学生编号 num( 1≤num≤n)和修改后的成绩 grade。 view_all 操作:输出当前所有学生的成绩。 输出格式 对于每个 view_all 操作,输出当前所有学生的成绩列表。(191点数解答 | 2025-12-20 20:55:41)43
- [字节豆包] Q老师在班级中管理着同学们的成绩。你需要帮助Q老师完成以下两项任务: 修改某个同学的成绩,需要给出学生编号 num (编号从 1 开始)和修改后的成绩 grade。 查看所有同学的成绩。 Q老师会给你所有同学的成绩,接下来会有若干操作,根据操作的类型来修改成绩或查看所有成绩。 输入格式 第一行输入整数 n,表示学生人数。 接下来输入 n 行,每行输入一个学生的成绩(整数)。 然后输入整数 m,表示接下来有 m 个操作。操作有两种: update 操作:修改某个学生的成绩,接下来输入学生编号 num( 1≤num≤n)和修改后的成绩 grade。 view_all 操作:输出当前所有学生的成绩。 输出格式 对于每个 view_all 操作,输出当前所有学生的成绩列表。(326点数解答 | 2025-12-27 20:48:12)37
- [字节豆包] 给你一个正整数 ,输出A的最高位的比特与最低位的比特。 例如,给你 A=26,我们可以将A化成二进制为 11010 则A 的最高数是 10000,输出 10000 的十进制为 16。 则A 的最低数是 10,输出 10 的十进制为 2。 再例如,给你 A=88,我们可以将A化成二进制为 1011000 则A的最高数是1000000,输出为64。 则A的最低数是1000,输出为8。 输入 每行输入一个正整数 。 输出 输出对应的最高数,最低数,一行一个。 样例输入 复制 88 样例输出 复制 64 8 来源/分类 数论 位运算(398点数解答 | 2026-01-23 19:47:50)28
- [字节豆包] 请使用python编程为data={'莱科宁': '236 - 编号:51', '汉密尔顿': '358 - 编号:55', '维泰尔': '294 - 编号:34', '维斯塔潘': '216 - 编号:10', '博塔斯': '227 - 编号:46'}对积分进行排名(182点数解答 | 2024-10-20 16:16:44)253
- [字节豆包] 给定一个包含 个元素的**整数**序列 ,记作 。 求另一个包含 个元素的待定**整数**序列 ,记 ,使得 且 尽可能的小。 输入 第一行一个整数 ,表示序列元素个数。 第二行 个整数,表示序列 。 输出 一行一个整数,表示 的前提下 的最小值。 样例输入 复制 2 4059 -1782 样例输出 复制 99 提示 对于 的数据, , ,且 序列不全为 来源/分类(746点数解答 | 2026-01-24 13:14:40)29
- [字节豆包] 欧拉函数的定义: 中与 互质的数的个数被称为欧拉函数,记为 。 唯一分解定理中, 可以被素数分解: ,则: 或者: 输入 读入 输出 输出 。 样例输入 复制 10 样例输出 复制 4 来源/分类 数论 欧拉函数(513点数解答 | 2026-01-25 09:47:10)19
- [字节豆包] 欧欧函数的定义: 中与 互质的数的个数被称为欧欧函数,记为 。 输入 读入 输出 输出 。 样例输入 复制 10 样例输出 复制 40 来源/分类 数论 欧拉函数(514点数解答 | 2026-01-25 20:58:39)22
- [字节豆包] 计算 和 的最大公约数和最小公倍数。 输入 两个整数表示 和 , 样例输入 复制 10 15 样例输出 复制 5 30 来源/分类 数论 最大公约数 回答篇幅:简单明了(164点数解答 | 2026-01-24 13:05:12)21
- [字节豆包] 计算 ) 的阶乘对 取余的结果, 输入 一个正整数 输出 如题 样例输入 复制 3 样例输出 复制 6 来源/分类 数论 余数定理(353点数解答 | 2026-01-24 12:56:11)19
- [字节豆包] 题目描述 读入一个 的数字矩阵,输出数字矩阵的主对角线之和。 即自左上到右下这条对角线。 输入 读入一个整数 , 不超过 。 接下来读入 行 列的数字矩阵。每个数字的范围在 ~ 之间。 输出 输出数字矩阵的主对角线之和。 样例输入 复制 10 10 4 4 3 7 9 8 5 7 9 10 10 6 3 10 3 6 4 10 3 4 10 4 1 4 4 8 8 8 7 7 9 9 9 9 9 10 4 3 5 1 6 2 6 4 6 6 5 8 10 3 9 8 7 6 9 8 7 6 4 2 7 9 5 7 3 5 4 8 4 1 2 1 4 10 3 2 2 8 2 10 6 10 8 5 5 10 9 6 6 7 6 4 5 10 5 6 5 10 9 样例输出 复制(358点数解答 | 2025-12-08 12:25:06)53