• 蓝桥杯2023年第十四届省赛真题-平方差--题解


    蓝桥杯2023年第十四届省赛真题-平方差

    时间限制: 3s 内存限制: 320MB 提交: 2379 解决: 469

    题目描述

    给定 L, R,问 L ≤ x ≤ R 中有多少个数 x 满足存在整数 y,z 使得 x = y2 − z2。

    输入格式

    输入一行包含两个整数 L, R,用一个空格分隔。

    输出格式

    输出一行包含一个整数满足题目给定条件的 x 的数量。

    样例输入

    复制

    1 5

    样例输出

    复制

    4

    提示

    1 = 1^2 − 0^2 ;

    3 = 2^2 − 1^2 ;

    4 = 2^2 − 0^2 ;

    5 = 3^2 − 2^2 。

    对于 40% 的评测用例,LR ≤ 5000 ;

    对于所有评测用例,1 ≤ L ≤ R ≤ 10^9 。

    【思路解析 】

    暴力尝试中总结答案的规律

    【代码实现】

    1. import java.util.Scanner;
    2. /**
    3. * @ProjectName: study3
    4. * @FileName: Ex1
    5. * @author:HWJ
    6. * @Data: 2023/9/16 22:27
    7. */
    8. public class Ex1 {
    9. public static void main(String[] args) {
    10. Scanner input = new Scanner(System.in);
    11. int L = input.nextInt();
    12. int R = input.nextInt();
    13. //System.out.println(getNums2(L, R));
    14. System.out.println(getNums3(L, R));
    15. }
    16. public static int getNums1(int L, int R){
    17. // 这个方法可行,但是时间复杂度为O(N^2),不满足题目要求
    18. int s = (R + 1) / 2;
    19. int e = (int) Math.sqrt(L) + 1;
    20. int ans = 0;
    21. boolean[] have = new boolean[R - L + 1];
    22. for (int i = s; i >= e; i--) {
    23. for (int j = i - 1; j >= 0; j--) {
    24. int a = (i + j) * (i - j);
    25. if (a >= L && a <= R && !have[a - L]) {
    26. ans++;
    27. have[a - L] = true;
    28. } else if (a > R) {
    29. break;
    30. }
    31. }
    32. }
    33. return ans;
    34. }
    35. public static int getNums2(int L, int R){
    36. // 通过观察所有可行的x发现 x要么为奇数要么为4的倍数
    37. int ans = 0;
    38. for (int i = L; i <= R; i++) {
    39. if (i % 4 == 0 || i % 2 != 0){
    40. ans++;
    41. }
    42. }
    43. return ans;
    44. }
    45. public static int getNums3(int L, int R){
    46. // 通过观察所有可行的x发现 x要么为奇数要么为4的倍数
    47. // 得到这个规律后,可以统计这样的数目应当为 F(R) = R / 4 + (R + 1) / 2;假设 L == 1
    48. // 所以实际数目应该为F(R) - F(L - 1)
    49. return (R / 4 + (R + 1) / 2) - ((L - 1) / 4 + (L) / 2);
    50. }
    51. }

  • 相关阅读:
    直播相关——声网rtc SDK
    从源码看vue(v2.7.10)的computed的实现原理
    Unix系统用户下载内容存放位置
    2023南京财经大学计算机考研信息汇总
    开发必备Liunx常用的几个命令
    template 推导
    Kubecost - Kubernetes 开支监控和管理
    MySQL性能调优,这个工具最有用(中)
    Python可视化必备,在Matplotlib/Seaborn中轻松玩转图形拼接!
    数字孪生轨道交通:“智慧化”监控疏通城市运行痛点
  • 原文地址:https://blog.csdn.net/weixin_73936404/article/details/132894089