[蓝桥杯 2023 省 A] 平方差
题目描述
给定 ,问 中有多少个数 满足存在整数 使得 。
输入格式
输入一行包含两个整数 ,用一个空格分隔。
输出格式
输出一行包含一个整数满足题目给定条件的 的数量。
样例 #1
样例输入 #1
1 5
样例输出 #1
4
提示
【样例说明】
【评测用例规模与约定】
对于 的评测用例,;
对于所有评测用例,。
第十四届蓝桥杯大赛软件赛省赛 C/C++ 大学 A 组 C
思路
由平方差公式可知, 可以拆分为。易知 和 具有相同的奇偶性。当两者为奇数时,可以是1和x;当两者为偶数时,可以是2和x/2。则可以是奇数或者4的倍数。因此,程序通过计算区间内奇数的个数和4的倍数的个数,然后将两者相加,得到满足条件的的个数。
首先定义两个辅助函数和,函数用于求1到x的奇数个数,函数用于求1到x的4的倍数个数。
然后读取输入的两个数和。然后计算满足题目条件的的数量,即计算,其中和是前面定义的两个函数。最后输出计算结果。
AC代码
#include <algorithm>
#include <iostream>
#define AUTHOR "HEX9CF"
using namespace std;
using ll = long long;
const int N = 1e6 + 7;
const int INF = 0x3f3f3f3f;
const ll MOD = 1e9 + 7;
// 求1到x的奇数个数
int a(int x) { return (x + 1) >> 1; }
// 求1到x的4的倍数个数
int b(int x) { return x / 4; }
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int l, r;
cin >> l >> r;
cout << (a(r) - a(l - 1)) + (b(r) - b(l - 1)) << "\n";
return 0;
}