最快求一个数的位数

大佬勿喷,适用新手

功能

        求一个十进制数的位数

代码

    int n=1234;   //求n的位数

    int s=1,len=0;
    while(s<=n){
        s*=10;
        len++;
    }

    cout<<len<<endl;

拓展功能

        将a=1,2,3,4,5,32,33,34,64一一对应转化

        为b=0,1,1,2,2,5,5,5,6(即2^n不大于a,b为最大的n)

代码

int a[9]={1,2,3,4,5,32,33,34,64},b[10];

    for(int i=0;i<9;i++){
        int s=1,len=-1;
        while(s<=a[i]){
            s*=2;
            len++;
        }
        b[i]=len;
        cout<<b[i]<<" ";
    }

 优点

        除了直接打表(打表缺点很明显,数组下标最大不能超过5*10^8),这个方法时间复杂度几乎是最小(log (2) n)

        该方法很适合做暴力题,想一下开始时简洁地处理数据,会极大保留心态,每一次超常发挥都是从秒杀暴力题开始的!!!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

int 我

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值