免费注册 查看新帖 |

Chinaunix

广告
  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5088 | 回复: 14
打印 上一主题 下一主题

[C] 判断一个unsighed int中位为1是否为奇数 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-09-06 09:16 |只看该作者 |倒序浏览
int fun(unsigned x)
{
     int val = 0;
     while (x) {
         val ^= x;
         x >>= 1;
     }

     return val & 0x1;
}

这段代码的原理是什么

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
2 [报告]
发表于 2014-09-06 09:29 |只看该作者
原理是所有位在0bit处XOR噬~~

论坛徽章:
1
亥猪
日期:2014-09-10 11:43:17
3 [报告]
发表于 2014-09-06 11:23 |只看该作者
凑个热闹。
  1. int fun(unsigned x)
  2. {
  3.         for(int i = sizeof(unsigned) * 8; i >>= 1; x ^= x >> i);
  4.         return x & 1;
  5. }
复制代码

评分

参与人数 1可用积分 +10 收起 理由
amarant + 10 赞一个!

查看全部评分

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
4 [报告]
发表于 2014-09-06 12:15 |只看该作者
回复 3# Kurosaki_Ichigo


    for(int i = sizeof(unsigned) * 8; i >>= 1; x ^= x >> i);

论坛徽章:
1
亥猪
日期:2014-09-10 11:43:17
5 [报告]
发表于 2014-09-06 12:47 |只看该作者
folklore 发表于 2014-09-06 12:15
回复 3# Kurosaki_Ichigo

哦?是我哪个字符敲的让你觉得好笑了?

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
6 [报告]
发表于 2014-09-06 13:02 |只看该作者
回复 5# Kurosaki_Ichigo


    for(int i = sizeof(unsigned) * 8; i >>= 1; x ^= x >> i);

婑油, 难道不是i-=1(或--i)?

论坛徽章:
1
亥猪
日期:2014-09-10 11:43:17
7 [报告]
发表于 2014-09-06 13:41 |只看该作者
好吧,还有谁想笑?

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
8 [报告]
发表于 2014-09-06 14:45 |只看该作者
如果程序中大量使用,还是查表效率最高。否则,还是节约点内存吧。

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
9 [报告]
发表于 2014-09-06 15:01 |只看该作者


  1. int get_word_parity(unsigned short val)
  2. {
  3.     int cnt;

  4.     cnt = 0;
  5.     while (val) {
  6.         cnt += val & 1;
  7.         val >>= 1;
  8.     }
  9.     return cnt & 1;
  10. }

复制代码

论坛徽章:
2
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
10 [报告]
发表于 2014-09-06 15:07 |只看该作者

  1. int get_word_parity(unsigned short val, const char tab[256])
  2. {
  3.     return (tab[*(unsigned char *)&val] + tab[*((unsigned char *)&val + 1)]) & 1;
  4. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP