免费注册 查看新帖 |

Chinaunix

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

[C] 如何计算某char变量bit位为1的总数目? [复制链接]

论坛徽章:
0
11 [报告]
发表于 2009-06-25 14:06 |只看该作者

回复 #5 daybreakcx 的帖子

还是x & (x - 1)比较有效率,相比移位来讲,查表意义不大吧,还得去构造一个数组

呵呵,这题目怎么经常面试到,还有反转位序,反转链表之类

论坛徽章:
0
12 [报告]
发表于 2009-06-25 14:26 |只看该作者

回复 #7 bruceteen 的帖子

七楼的方法比较好

论坛徽章:
0
13 [报告]
发表于 2009-06-25 16:15 |只看该作者
原帖由 sunchiang 于 2009-6-25 13:21 发表
把所有可能存进一个数组,直接查表,不知道我的意思你明白不?


那人家如果让你计算一个int型的数里面的1的个数,你也查表啊

论坛徽章:
0
14 [报告]
发表于 2009-06-25 16:22 |只看该作者
原帖由 bruceteen 于 2009-6-25 09:33 发表
size_t func( char x )
{
    x = (x & 0x55) + ((x>>1) & 0x55);
    x = (x & 0x33) + ((x>>2) & 0x33);
    x = (x & 0x0f) + ((x>>4) & 0x0f);

    return x;
}

#include
using namespace std ...


这个算法看着迷糊,能否说一下原理

论坛徽章:
0
15 [报告]
发表于 2009-06-25 16:24 |只看该作者
x & (x - 1)和移位哪个效率高?怎么确定的

论坛徽章:
0
16 [报告]
发表于 2009-06-25 17:42 |只看该作者
原帖由 eveson 于 2009-6-25 16:24 发表
x & (x - 1)和移位哪个效率高?怎么确定的

前者,前者算的是O(n)(n是1个数),后者是O(m)(m是位数),特别是稀疏的时候前者高,但是位数比较少其实都差不多

论坛徽章:
0
17 [报告]
发表于 2009-06-25 18:07 |只看该作者
谁说查表法没意义?禁止误导初学者!

int型怎么了?你不会查4次啊?笨!

论坛徽章:
0
18 [报告]
发表于 2009-06-27 10:16 |只看该作者
原帖由 JohnBull 于 2009-6-25 18:07 发表
谁说查表法没意义?禁止误导初学者!

int型怎么了?你不会查4次啊?笨!



对对对,牛逼!

咱当时没想到。不好意思。

论坛徽章:
0
19 [报告]
发表于 2009-06-27 17:16 |只看该作者
某年某次的某个面试中,我也遇到过这个问题,当时顺手就写了一个移位的程序,后来发现的确好多地方可以优化。

个为认为查表是比较好的,时间复杂度比较小。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
20 [报告]
发表于 2009-06-28 11:16 |只看该作者
原帖由 bsdc 于 2009-6-25 14:06 发表
还是x & (x - 1)比较有效率,相比移位来讲,查表意义不大吧,还得去构造一个数组

呵呵,这题目怎么经常面试到,还有反转位序,反转链表之类

你这个方法好!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP