原题链接:蓝桥杯2023年第十四届省赛真题-平方差
解题思路:
只有当 x 是偶数时(即 x 的最低位是0,或者说 x 是4的倍数),x 才能表示为两个整数的这是因为奇数减去奇数或偶数减去偶数总是得到偶数,而且只有当 x 模4的余数是0或3时,x 才能被表示为两个整数的平方差。
因此,代码中的条件 i % 4 == 0 || (i & 1) == 1 实际上是在检查 x 是否为偶数((i & 1) == 1 检查最低位是否为1,即是否是奇数)。由于所有的奇数减去一个奇数仍然是偶数,所以这个条件确保了 x 是偶数。然而,这个条件并没有确保 x 能被表示为两个整数的平方差,因为它没有考虑到 x 模4的余数必须是0或3。正确的条件应该是检查 x 是否是4的倍数,即 i % 4 == 0。
综上所述,正确的条件应该是 i % 4 == 0,而不是 i % 4 == 0 || (i & 1) == 1。后者实际上包含了所有的奇数,但并不是所有的奇数都能表示为两个整数的平方差。
注意事项:
参考代码:
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int l = scanner.nextInt(); int r = scanner.nextInt(); int res = 0; for (int i = l; i <= r; i++) { if (i % 4 == 0 || (i & 1) == 1) res++; } System.out.print(res); } }
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复