标签:一个 int 整数 ++ return scan lld print 表示
只有1行,为2个正整数,用一个空格隔开:
k N
(k、N的含义与上述的问题描述一致,且3≤k≤15,10≤N≤1000)。
计算结果,是一个正整数(在所有的测试数据中,结果均不超过2.1*10^9)。(整数前不要有空格和其他符号)。
#include<stdio.h>
int n2[1010];
long long l1 = 1;  
long long n, k;  
long long sm(long long i,long long k)  
{  
    long long s = 1;  
    int j;  
    for (j = 1; j <= i; j++)  
    {  
        s *= k;  
    }  
    return s;  
}
int main()  
{  
    int i;  
    scanf("%lld %lld",&k,&n); 
    while(n > 0)  
    {  
        n2[l1++] = n % 2;  
        n /= 2;  
    }  
    l1--;  
   long long s = 0;  
    for (i = 1; i <= l1; i++)  
    {  
        if (n2[i])  
        {  
            s += sm(i-1,k);  
        }  
    } 
    printf("%lld",s);  
    return 0; 
}
标签:一个 int 整数 ++ return scan lld print 表示
原文地址:https://www.cnblogs.com/minghaomaopao/p/10122272.html