对于L,R段 其数字总和与平方和(十进制)为co- 主要。 计算L,R段中满足上述条件的数字
我被困在sub21上 当R = 10 ^ 8并且最大R = 10 ^ 18时超过时间限制:
#include<bits/stdc++.h>
using namespace std;
class tinhtong
{
public:
long long getSum(long long n)
{
long long int sum = 0;
while (n != 0)
{
sum = sum + (n % 10);
n = n/10;
}
return sum;
}
};
class binhphuong
{
public:
long long getpow(long long n)
{
long long poww = 0;
while (n != 0)
{
poww = poww + (n % 10)*(n % 10);
n = n/10;
}
return poww;
}
};
int main()
{
tinhtong g;
binhphuong h;
long long TONG=0,k,l,ucln;
long long int m,n;
cin>>n>>m;
for(n;n<=m;n++)
{
ucln=0;
k=g.getSum(n);
l=h.getpow(n);
while(k!=0 && l!=0)
{
if(k>l)
k-=l;
else
l-=k;
}
if(k==0)
ucln=l;
else
ucln=k;
if (ucln==1)
TONG++;
}
cout<<TONG;
return 0;
}
答案 0 :(得分:0)
如注释中所述,您可以在一个循环中计算总和和平方和,从而避免多次调用相同的%
操作。
此外,要计算两个数字为互质数,最好使用Euclide的算法,该算法使用取模而不是减法。代码如下。
在此代码中,我使用了平方和大于或等于和的事实。
我还使用以下事实:如果总和是2的倍数,那么平方和也是如此。
如果此代码不够快,您可以尝试在注释中提出建议,首先将数字转换为字符串。
另一种可能性是在计算GCD之前检查两个数字是否均为3或5的倍数,因为GCD的计算可能会更长。
#include <iostream>
#include <tuple>
std::pair<long long, long long> getSum_pow(long long n) {
long long int sum = 0;
long long int sumP = 0;
while (n != 0) {
long long r = n%10;
sum += r;
sumP += r*r;
n = n/10;
}
return {sumP, sum};
};
int main() {
long long TONG = 0, a, b;
long long int m, n;
std::cin >> n >> m;
for(; n <= m; n++) {
std::tie (a, b) = getSum_pow(n);
if (b%2 == 0) continue;
while (b != 0) {
a = a%b;
std::swap (a, b);
}
if (a == 1) {
TONG++;
}
}
std::cout << TONG;
return 0;
}