php专区

 首页 > php专区 > PHP进阶 > 算法 > 从1到1亿这1亿个数里面有多少个1?

从1到1亿这1亿个数里面有多少个1?

分享到:
【字体:
导读:
         摘要:乍看这题真够唬人的,群里看到这个题目后争先恐后的说看法。最简单的办法不外乎就是遍历每个数,然后toString()看看里面有多少个1,最后全部加起来,这是我们得到标准答案的办法。群里3个人写了3个笨方法都跑出来了,3个笨方法,呵呵有意思,笨方法也不一样。程序的实现真是变幻莫测。 ...

从1到1亿这1亿个数里面有多少个1?

乍看这题真够唬人的,群里看到这个题目后争先恐后的说看法。最简单的办法不外乎就是遍历每个数,然后toString() 看看里面有多少个1,最后全部加起来,这是我们得到标准答案的办法。

群里3个人写了3个笨方法都跑出来了,3个笨方法,呵呵 有意思,笨方法也不一样。 程序的实现真是变幻莫测。

var re = /1{1}/g;
var max = 1 * 10000 * 10000;
getTotal(f);
getTotal(f1);
getTotal(f2);
function getTotal(func)
{
    var total = 0;
    var begin = new Date();
    for(var i= 1 ;i <= max;i++)
    {
        total += func(i);
    }
    var end = new Date();
    var timespan = end - begin;
    alert("开始时间:"+begin + "n 结束时间:"+end +"n总耗时:"+timespan + "毫秒 n 总数:"+total);
}
function f(num)
{
    var t = 0;
    while(num)
    {
        if(num < 10){ if(num==1)t++;break;}
        var i = num % 10;
        if(i == 1) t++;    
        num = parseInt(num / 10);
    }
    return t;
}
function f1(num)
{
    var str = num.toString()
    var t = 0;
    for(var i=0;i
    
    

当数量少的时候第一种最快,显然嘛,没有处理字符串的步骤。按理说数量越大他越有优势。 可是实测结果,3个都差不多。但是用C#跑的话,第一个明显越来越有优势。。。。

但是出题人肯定不是这样想的,很多人都在说自己的技巧与看法,我也思考了很久。

先拿 100来说 ,100里面有多少个1?

10
11
12
13
14
15
16
17
18
19
01
11
21
31
41
51
61
71
81
91

故意这么排列是我们可以把 0~99看作是 1个长度为2的数组, 1位为1时,2位的可能性是10,2位为1时1位的可能性为10,所以 0~99应该有20个1,而100有1个所以是21个。

999就应该是 1*10*10 + 10*1*10 + 10*10*1 = 300

400呢? 因为首位只能出现0~3 ,所以应该是 1*10*10 + 4*1*10 + 4*1*10

4 0000 0000 应该是 1 * (10^8) + 4*(10^7) * 8 = 420000000

本文地址:http://www.nowamagic.net/librarys/veda/detail/1331,欢迎访问原出处。

从1到1亿这1亿个数里面有多少个1?
分享到:
被1至20整除的最小正整数问题
被1至20整除的最小正整数问题 求能被1到20的数整除的最小正整数。最直觉的方法是求1到20这20个数的最小公倍数。 求n个数的最小公倍数,以a,b,c三个数为例,他们的最小公倍数等于:先求a与b的最小公倍数m,然后m和c的最小公倍数即着三个数的最小公倍数。 求两个数a,b的最小公倍数嘛,先取出其中较...
趣味算法:猴子搬香蕉问题
趣味算法:猴子搬香蕉问题 在博客园一篇文章末尾看到一个有趣的数学问题,据说是小学4年级的题目,摘引如下: 一只小猴摘了300个香蕉,需要搬回家,每次最多搬100个。小猴离家100米,它每走1米,都需要吃掉1个香蕉来补充能量,请问它最多能够搬回家多少个? 思考了好一会,写了个小程序模拟这一过程: $bananas ...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……