依旧的博客
技术学习
C++博客
首页
新随笔
联系
聚合
管理
17 Posts :: 1 Stories :: 2 Comments :: 0 Trackbacks
常用链接
我的随笔
我的评论
我参与的随笔
留言簿
(3)
给我留言
查看公开留言
查看私人留言
随笔分类
(15)
编程(13)
动手(1)
基础(1)
业务
随笔档案
(17)
2007年4月 (1)
2007年1月 (1)
2006年10月 (1)
2006年9月 (1)
2006年8月 (2)
2006年6月 (1)
2006年5月 (10)
文章分类
(9)
编程(4)
动手(1)
基础(1)
思想(3)
文章档案
(1)
2007年5月 (1)
搜索
最新评论
1. re: 思路欣赏
确实没有太直接的用处,训练思维吧
--zliner
2. re: 思路欣赏
没有看明白,但在看完了以后,会想说,这样的想法,能帮助我们解决哪些问题?
--E398
阅读排行榜
1. MVC模式和文档/视图结构(3029)
2. 观察者模式(2275)
3. C/S通信和Winsock编程(2261)
4. 错误码、异常和断言(1432)
5. COM基本概念和COM模型(1150)
评论排行榜
1. 思路欣赏(2)
2. MFC的五种基本机制(0)
3. 多操作系统的引导(0)
4. 用例分析基础(0)
5. MVC模式和文档/视图结构(0)
思路欣赏
欣赏好的思路是一件愉快的事,特别是对我不会做的题目。
1. 问题:对32位的二进制整数,不用循环,求出其中1的个数。
#define
POW(c) (1<<(c))
#define
MASK(c) (((unsigned long)-1) / (POW(POW(c)) + 1))
#define
ROUND(n, c) (((n) & MASK(c)) + ((n) >> POW(c) & MASK(c)))
int
bit_count(unsigned
int
n)
{
n
=
ROUND(n,
0
);
n
=
ROUND(n,
1
);
n
=
ROUND(n,
2
);
n
=
ROUND(n,
3
);
n
=
ROUND(n,
4
);
return
n;
}
基本的想法是把所有的1加起来,得到的就是1的个数。我们需要把这些1分离出来,每个1都是平等的,与其位置无关。难题在于不能一个一个去取,那就用到了循环,当然递归也是不允许的。需要有一种统一的办法,可是很难想象具体该怎样。我们逐步地做这件事,假设前16位和后16位分别求得了1的个数,那么加起来就行了。16位二进制中的1仍然是未知的,随机出现的,问题的性质没有变,但我们可以继续分解,这种逐步的做法不一定就意味着递归。每个16位分解为两个8位,...,每个2位分解为两个1位,把两个1位上的数相加就是这两位上1的个数。现在需要取出每一位上的数吗?如果想到了这个问题,就离最终的思路不远了。现在32位已经分成了16个两位,很容易将其看作两个16位,一个是所有奇数位,一个是所有偶数位。我们不难把这两个16位分开,然后移位相加,就求出了每两位中1的个数。到了这一步,以后的思路就很自然了。
参考:
《计算二进制位'1'的个数》来自
http://kaikai.cnblogs.com
posted on 2006-05-12 23:14
依旧的博客
阅读(642)
评论(2)
编辑
收藏
引用
所属分类:
编程
Feedback
#
re: 思路欣赏
2006-06-23 18:54
E398
没有看明白,但在看完了以后,会想说,这样的想法,能帮助我们解决哪些问题?
回复
更多评论
#
re: 思路欣赏
2006-06-23 20:44
zliner
确实没有太直接的用处,训练思维吧
回复
更多评论
刷新评论列表
只有注册用户
登录
后才能发表评论。
【推荐】100%开源!大型工业跨平台软件C++源码提供,建模,组态!
相关文章:
用例分析基础
MFC的五种基本机制
思路欣赏
几种排序方法的实现
多线程通信的机制
COM基本概念和COM模型
排序的方法
数据库范式及其涵义
C/S通信和Winsock编程
论面向对象
网站导航:
博客园
IT新闻
BlogJava
博问
Chat2DB
管理
Powered by:
C++博客
Copyright © 依旧的博客