MIT HAKMEM算法-BitCount算法
MIT HAKMEM算法
1.问题来源
- 问题描述:
#include <iostream>
using namespace std;
unsigned int fib(int n)
{
	if(n==0 || n==1)
		return 1;
	return f(n-1)+f(n-2);
}
void count(int n)
{
	unsigned int temp= n - ((n>>1)&033333333333) - ((n>>2)&011111111111)
	std::cout<< ((temp+(temp>>3))&030707070707) %63 <<std::endl;
}
int main()
{
	count(f(7));
	count(f(9));
	return 0;
}
哈哈,看见这个题
这不是 fib数列递归运算后再进行二进制的运算
| 序号 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 
|---|---|---|---|---|---|---|---|---|---|---|---|
| fib | 1 | 1 | 2 | 3 | 5 | 8 | 13 | 21 | 34 | 55 | 89 | 
摊手、哈哈 菜 计算不出来!
查找资料 - 这个count函数就是统计bit个数的
f(7)=21=00010101B
f(9)=55= 00110111B
输出: 3,5
2.问题描述:
现在来研究研究这个count函数-统计整数(二进制)中“1”的个数
一些知识点
- 1.整数性的数值 
 \(i=a_{0} * 2^{0} + a_{1} * 2^{1}+a_{2}*2^{2}+...+a_{n}* 2^{n}\)
 所以count “1”的个数
 \(count=a_{0}+a_{1}+a_{2}+...+a_{n}\)
- 2.对于任何自然数n的N次幂 \(n^{N}\),用n-1 取模得数为1 
\]
利用归纳法来证明:
假设 \(n^{k-1} \%(n-1)=1\) 成立
证明 \(n^{k} \%(n-1)=1\)
\]
\]
- 3.一个系数 为\(a_{i}\)以n为底的多项式P(N)
\]
保证$\sum a_{i} $小于余数 $\sum a_{i} < n-1 $
可以推导出
\]
32bit的整数,可以取 n=64 n-1=63作为余数来实现count
- 4.将32位二进制数的每6位作为一个单位,看作以64为底的多项式 
 \(I=t_{0}* 64^{0}+ t_{1} * 64^{1} +...+t_{n} * 64^{n}\)
 各个单位中的6位数变为这6位中含有的'1'的个数,再用63取模,就可以得到所求的总的'1'的个数。
- 5.其中任意一项的6位数ti进行考虑,最简单的方法显然是对每次对1位进行mask然后相加 
 (ti>>5)&(000001) + (ti&>>4)(000001) + (ti>>3)&(000001) + (ti>>2)&(000001) + (ti>>1)&(000001) + ti&(000001)
初步实现代码
int bitcount(unsigned int n)
{
    unsigned int tmp;
    tmp = (n &010101010101)
     +((n>>1)&010101010101)
     +((n>>2)&010101010101)
     +((n>>3)&010101010101)
     +((n>>4)&010101010101)
     +((n>>5)&010101010101);
    return (tmp%63);
}
- 6.位数中最多只有6个'1',也就是000110,只需要3位有效位。上面的式子实际上是以1位为单位提取出'1'的个数再相加求和求出6位中'1'的总个数的,所以用的是&(000001)。如果以3位为单位算出'1'的个数再进行相加的话,那么就完全可以先加后MASK。
 tmp = (ti>>2)&(001001) + (ti>>1)&(001001) + ti&(001001)
 (tmp + tmp>>3)&(000111)
int bitcount(unsigned int n)
{
    unsigned int tmp;
    tmp = (n &011111111111)
     +((n>>1)&011111111111)
     +((n>>2)&011111111111);
    tmp = (tmp + (tmp>>3)) &030707070707;
    return (tmp%63);
}
- 7.最终的优化代码
    unsigned int tmp;
    tmp = n
        - ((n >> 1) & 033333333333)
        - ((n >> 2) & 011111111111);
    tmp = (tmp + (tmp >> 3)) & 030707070707
    return (tmp%63);
}
MIT HAKMEM算法-BitCount算法的更多相关文章
- MIT公开课:算法导论 笔记(一)
		课程链接:http://open.163.com/special/opencourse/algorithms.html 第一课:算法分析基础 1.介绍插入排序与归并排序,计算并比较最坏运行时间 2.算 ... 
- random array & shuffle 洗牌算法 / 随机算法
		random array & shuffle shuffle 洗牌算法 / 随机算法 https://en.wikipedia.org/wiki/Fisher–Yates_shuffle ES ... 
- GMM算法k-means算法的比较
		1.EM算法 GMM算法是EM算法族的一个具体例子. EM算法解决的问题是:要对数据进行聚类,假定数据服从杂合的几个概率分布,分布的具体参数未知,涉及到的随机变量有两组,其中一组可观测另一组不可观测. ... 
- 简单易学的机器学习算法——EM算法
		简单易学的机器学习算法——EM算法 一.机器学习中的参数估计问题 在前面的博文中,如“简单易学的机器学习算法——Logistic回归”中,采用了极大似然函数对其模型中的参数进行估计,简单来讲即对于一系 ... 
- 最短路径算法-Dijkstra算法的应用之单词转换(词梯问题)(转)
		一,问题描述 在英文单词表中,有一些单词非常相似,它们可以通过只变换一个字符而得到另一个单词.比如:hive-->five:wine-->line:line-->nine:nine- ... 
- 重新想象 Windows 8 Store Apps (31) - 加密解密: 哈希算法, 对称算法
		原文:重新想象 Windows 8 Store Apps (31) - 加密解密: 哈希算法, 对称算法 [源码下载] 重新想象 Windows 8 Store Apps (31) - 加密解密: 哈 ... 
- Hash散列算法  Time33算法
		hash在开发由频繁使用.今天time33也许最流行的哈希算法. 算法: 对字符串的每一个字符,迭代的乘以33 原型: hash(i) = hash(i-1)*33 + str[i] ; 在使用时.存 ... 
- 变易算法 - STL算法
		欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/mutating-algorithms.h ... 
- STL非变易算法 - STL算法
		欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/1394600460.html 原创:ST ... 
随机推荐
- 第一章:   初识Java
			计算机程序:计算机为完成某些功能产生的一系列有序指令集合. Java技术包括:JavaSE(标准版) JavaEE(企业版) ---JavaME(移动版) 开发Java程序步骤:1.编写 2.编译 3 ... 
- 终极版Servlet——我只能提示您路过别错过
			终极版Servlet 前言:这两天看了SSM框架,本来是想往后继续学的,脑门一转又回来了,不能就这么不声不响的走了,看了这么多天的Servlet,再写最后一篇做个告别吧,这篇起名为终极版,是我现在所能 ... 
- 【Android】java.lang.SecurityException: getDeviceId: Neither user 10065 nor current process has android.permission.READ_PHONE_STATE
			RT, 异常信息如下: java.lang.SecurityException: getDeviceId: Neither user 10065 nor current process has and ... 
- 【iOS】Xcode 离线文档
			Xcode 本身下载太慢…… Apple 官方文档地址:https://developer.apple.com/library/downloads/docset-index.dvtdownloadab ... 
- jplayer
			简介 jplayer是个用JavaScript写的完全免费和开源的媒体库(media library).作为jQuery插件的一员,使用jPlayer可以在你的网页上轻松加入跨平台的音乐和视频 使用方 ... 
- Python基础总结之初步认识---clsaa类(上)。第十四天开始(新手可相互督促)
			最近的类看着很疼,坚持就是胜利~~~ python中的类,什么是类?类是由属性和方法组成的.类中可能有很多属性,以及方法. 我们这样定义一个类: 前面是class关键字 后面school是一个类的名字 ... 
- 深入Apache NiFi 之源码学习
			前言 要问 Hortonworks 这家公司最有产品力的产品是什么,我觉得是 Apache NiFi.去年Cloudera 和 Hortonworks 合并之后,以 Cloudera 为主,两家公司进 ... 
- 使用Junit测试一个 spring静态工厂实例化bean 的例子,所有代码都没有问题,但是出现java.lang.IllegalArgumentException异常
			使用Junit测试一个spring静态工厂实例化bean的例子,所有代码都没有问题,但是出现 java.lang.IllegalArgumentException 异常, 如下图所示: 开始以为是代码 ... 
- 使用 OpenSSL 为 Nginx 创建自签名证书 并开启客户端身份验证
			本文章默认读者了解Openssl,CA,网站证书相关知识,直接实战!配置完成后,浏览器会显示"安全的HTTPS"连接.不会像其他文章那样,是红色警告的证书提示. 准备环境 笔者使用 ... 
- Java基础的一些知识点(一):接口interface
			1.接口的含义 接口可以理解成统一的协议, 而接口中的属性也属于协议中的内容.但是接口的属性都是公共的,静态的,最终的. 接口的成员特点: 1.成员变量只能是常量,默认修饰符 public stati ... 
