• 洛谷 P1062 数列


    题目描述

    给定一个正整数k(3≤k≤15),把所有k的方幂及所有有限个互不相等的k的方幂之和构成一个递增的序列,例如,当k=3时,这个序列是:

    1,3,4,9,10,12,13,…

    (该序列实际上就是:3^0,3^1,3^0+3^1,3^2,3^0+3^2,3^1+3^2,3^0+3^1+3^2,…)

    请你求出这个序列的第N项的值(用10进制数表示)。

    例如,对于k=3,N=100,正确答案应该是981。

    输入输出格式

    输入格式:

     

    输入文件只有1行,为2个正整数,用一个空格隔开:

    k N (k、N的含义与上述的问题描述一致,且3≤k≤15,10≤N≤1000)。

     

    输出格式:

     

    输出文件为计算结果,是一个正整数(在所有的测试数据中,结果均不超过2.1*109)。(整数前不要有空格和其他符号)。

     

    输入输出样例

    输入样例#1:
      3 100
    输出样例#1:
    981

    说明

    NOIP 2006 普及组 第四题

    题解:进制+找规律

    3^0,3^1,3^0+3^1,3^2,3^0+3^2,3^1+3^2,3^0+3^1+3^2,

    1     2      3       4       5       6      7       第i个

    1   10     11    100     101     110     111    i的二进制表示

    答案就是 2的进制串的数*k^(二进制的位)

    假如k=2,n=5

    5的二进制是 101,那么答案就是2^0+2^2

    代码:

    #include<iostream>
    #include<cstdio>
    #include<cstring>
    #define LL long long
    using namespace std;
    
    int n,k;
    LL ans;
    
    LL ksm(int x,int y){
        LL ret=1;
        while(y){
            if(y&1)ret=ret*x;
            x=x*x;
            y>>=1;
        }
        return ret;
    }
    
    int main(){
        scanf("%d%d",&k,&n);
        for(int i=0;n;i++){
            if(n&1)ans=ans+ksm(k,i);
            n>>=1;
        }
        cout<<ans<<endl;
        return 0;
    }
  • 相关阅读:
    maven第三章 maven使用入门
    各个软件产生的原因
    maven的pom.xml深入理解
    批量同步订单信息(包括状态)到订单中心心得
    数据库连接超时和go away、如何检测数据库的最大连接数
    记录错误日志的技巧
    架构思想总结同步和事务的具体应用
    业务逻辑复杂性处理
    日志系统总结
    php捕获异常的处理
  • 原文地址:https://www.cnblogs.com/zzyh/p/7663218.html
Copyright © 2020-2023  润新知