平方和的总和-coprime

时间:2019-06-05 14:53:07

标签: c++

  

对于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;
}

1 个答案:

答案 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;
}