免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: yzc2002
打印 上一主题 下一主题

据说是google的面试题,看谁的快 [复制链接]

论坛徽章:
0
111 [报告]
发表于 2009-03-04 23:33 |只看该作者
大家都 很牛啊
呵呵
这题貌似是《编程之美》上的啊
呵呵,看看书上的解答吧

1的数目.pdf

257.61 KB, 下载次数: 371

论坛徽章:
0
112 [报告]
发表于 2009-03-05 11:24 |只看该作者
原帖由 dragoxiao 于 2009-3-4 23:33 发表
大家都 很牛啊
呵呵
这题貌似是《编程之美》上的啊
呵呵,看看书上的解答吧


看出来是考算法,但没想出来,惭愧啊,

论坛徽章:
0
113 [报告]
发表于 2009-03-05 13:48 |只看该作者

回复 #113 yuanchengjun 的帖子

呵呵,这个效率才是最关键的地方,我想破脑袋也没想出来,算法这玩意儿太博大精深了啊

论坛徽章:
0
114 [报告]
发表于 2009-03-05 15:45 |只看该作者

回复 #28 yzc2002 的帖子

本帖最后由 yzc2002 于 2006-3-29 17:09 编辑

关注!!

论坛徽章:
0
115 [报告]
发表于 2009-03-27 10:14 |只看该作者

回复 #112 dragoxiao 的帖子

这个算法速度最快。

论坛徽章:
0
116 [报告]
发表于 2009-03-27 13:03 |只看该作者

回复 #1 yzc2002 的帖子

这么老的帖子又被翻出来了

论坛徽章:
0
117 [报告]
发表于 2011-05-09 10:57 |只看该作者

  1. #include <stdio.h>

  2. int
  3. main (int argc, char **argv)
  4. {
  5.   int n, index, sum, number, arr[100];
  6.   index = 0;
  7.   sum = 0;
  8.   n = 2;
  9.   for (n = 2;; n++)
  10.     {
  11.       index = 0;
  12.       number = n;
  13.       while (number != 0)
  14.         {
  15.           arr[index] = number % 10;
  16.           number /= 10;
  17.           if (arr[index] == 1)
  18.             {
  19.               sum++;
  20.             }
  21.           index++;
  22.         };
  23.       if (n == sum)
  24.         {
  25.           break;
  26.         }
  27.     }
  28. printf ("%d\n", n);
  29.   return 0;
  30. }
复制代码

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
118 [报告]
发表于 2011-06-03 16:46 |只看该作者
本帖最后由 cokeboL 于 2011-06-09 14:31 编辑

回复 1# yzc2002
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int count_1(num)
  4. {
  5.         unsigned long counter_1 = 0, counter_n = 0, n = 1, tmp;
  6.         while(n < 100000000){
  7.                 tmp = n;
  8.                 while( tmp > 0 ){
  9.                         if( tmp%10 == 1 )
  10.                                 counter_1++;
  11.                         tmp /= 10;
  12.                 }
  13.                 if( counter_1 == n )
  14.                         if( ++counter_n == num )
  15.                                 return n;
  16.                 n++;
  17.         }
  18. }

  19. int main()
  20. {
  21.         printf( "%d\n",count_1(2) );
  22. }
复制代码
时间不到1s。

不知道楼主说的1s是找出所有值还是只找到第二个,如果是找到所有,那1s太牛了,膜拜!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP