PHP中使用BigMap实例


Posted in PHP onMarch 30, 2015
<?php
//所谓的Bit-map就是用一个bit位来标记某个元素对应的Value, 而Key即是该元素。由于采用了Bit为单位来存储数据,因此在存储空间方面,可以大大节省。

/*

若 N =1 ; 申请内存空间为 int a[2] ; 
假设需要排序或者查找的总数N=10000000,那么我们需要申请内存空间的大小为int a[1 + N/32],其中:a[0]在内存中占32为可以对应十进制数0-31,依次类推: 

1.求十进制0-N对应在数组a中的下标: n/32 

2.求0-N对应0-31中的数: N%32=M

3.利用移位0-31使得对应32bit位为1: 1<<M,并置1;

举例 : 

如果想存储 3 
(1) a下标 30/ 32 = 0 ; 放在a[0] 中; 
(2) 3% 32 = 30; 
(3) 左移 30 位 01000000 00000000 00000000 00000000 这个对应的值$a[0] = 1073741824 ; 


1.求十进制0-N对应在数组a中的下标: 
十进制0-31,对应在a[0]中,先由十进制数n转换为与32的余可转化为对应在数组a中的下标。比如n=24,那么 n/32=0,则24对应在数组a中的下标为0。又比如n=60,那么n/32=1,则60对应在数组a中的下标为1,同理可以计算0-N在数组a中的下标。 

2.求0-N对应0-31中的数: 

十进制0-31就对应0-31,而32-63则对应也是0-31,即给定一个数n可以通过模32求得对应0-31中的数。 

3.利用移位0-31使得对应32bit位为1. 

找到对应0-31的数为M, 左移M位:即2^M. 然后置1.

 由此我们计算10000000个bit占用的空间:

1byte = 8bit

1kb = 1024byte

1mb = 1024kb
占用的空间为:10000000/8/1024/1024mb。

大概为1mb多一些。
 
 */
 
 class bigMap {
	 //使用两个字节保存 
	private $mask = 0x1f ;
	private $bitsperword = 32 ;
	// 移位的位数为5 pow(2,5) = 32 
	private $shift = 5 ;
	// 存储数据的数组 
	 public $bitArray = array(); 
 
	 /**
	 $i 对应的数归零 
	 */
	 function clearbit($i){
		 ////则将当前byte中的指定bit位取0,&后其他对方数组bit位必然不变,这就是 1 的妙用
		 // $i>>SHIFT 这里相当于 intval($i /32) ;
		 // $i & $this->mask 这里相当于 $i % $this->mask ,取余
		 @$this->bitArray[$i >> $this->shift] &= ~(1<<($i & $this->mask)); 
	}
 
 	 /**
	 $i 对应的数致1 
	 */
	 function setbit($i){
		 @$this->bitArray[$i >> $this->shift] |= (1<<($i & $this->mask)); 
	}
 
 //test 测试所在的bit为是否为1 
 function testbit($i){ 
		return $this->bitArray[$i >> $this->shift] & (1<<($i & $this->mask)); 
	} 	 
 }


$oBig = new bigMap() ; 

$oBig->setbit(30) ; 

var_dump($oBig->testbit(2)) ; 
var_dump($oBig->bitArray) ; 

echo decbin($oBig->bitArray[0]),"<br>";
PHP 相关文章推荐
谈谈新手如何学习PHP
Dec 14 PHP
超级简单的php+mysql留言本源码
Nov 11 PHP
PHP为表单获取的URL 地址预设 http 字符串函数代码
May 26 PHP
PHP分页函数代码(简单实用型)
Dec 02 PHP
Apache中php.ini的设置方法
Feb 28 PHP
深入mysql_fetch_row()与mysql_fetch_array()的区别详解
Jun 05 PHP
php中实现记住密码下次自动登录的例子
Nov 06 PHP
PHP实现接收二进制流转换成图片的方法
Jan 10 PHP
PHP基于ORM方式操作MySQL数据库实例
Jun 21 PHP
PHP实现的折半查询算法示例
Oct 09 PHP
PHP Class SoapClient not found解决方法
Jan 20 PHP
php使用json-schema模块实现json校验示例
Sep 28 PHP
PHP中使用Memache作为进程锁的操作类分享
Mar 30 #PHP
php中判断数组相等的方法以及数组运算符介绍
Mar 30 #PHP
smarty模板引擎之分配数据类型
Mar 30 #PHP
php生成不重复随机数、数组的4种方法分享
Mar 30 #PHP
smarty模板引擎基础知识入门
Mar 30 #PHP
php array_merge函数使用需要注意的一个问题
Mar 30 #PHP
PHP CodeIgniter框架的工作原理研究
Mar 30 #PHP
You might like
PHP生成不同颜色、不同大小的tag标签函数
2013/09/23 PHP
php微信公众平台示例代码分析(二)
2016/12/06 PHP
PHP设计模式之观察者模式定义与用法示例
2018/08/04 PHP
使用javascript过滤html的字符串(注释标记法)
2013/07/08 Javascript
JS中的this变量的使用介绍
2013/10/21 Javascript
JavaScript中instanceof运算符的用法总结
2013/11/19 Javascript
nodejs中操作mysql数据库示例
2014/12/20 NodeJs
jquery中checkbox全选失效的解决方法
2014/12/26 Javascript
原生js和jquery实现图片轮播淡入淡出效果
2015/04/23 Javascript
JS获取及验证开始结束日期的方法
2016/08/20 Javascript
JavaScript中this的四个绑定规则总结
2016/09/26 Javascript
使用vue.js实现联动效果的示例代码
2017/01/10 Javascript
JavaScript中数组Array.sort()排序方法详解
2017/03/01 Javascript
Spring shiro + bootstrap + jquery.validate 实现登录、注册功能
2017/06/02 jQuery
详解Vue组件之间通信的七种方式
2019/04/14 Javascript
VSCode搭建Vue项目的方法
2020/04/30 Javascript
[01:00:14]2018DOTA2亚洲邀请赛 4.6 淘汰赛 VP vs TNC 第三场
2018/04/10 DOTA
Pyhton中防止SQL注入的方法
2015/02/05 Python
python文件操作之目录遍历实例分析
2015/05/20 Python
面向初学者的Python编辑器Mu
2018/10/08 Python
用pycharm开发django项目示例代码
2018/10/24 Python
在pycharm中配置Anaconda以及pip源配置详解
2019/09/09 Python
python matplotlib 绘图 和 dpi对应关系详解
2020/03/14 Python
python 实现全球IP归属地查询工具
2020/12/18 Python
html5标记文字_动力节点Java学院整理
2017/07/11 HTML / CSS
写clone()方法时,通常都有一行代码,是什么?
2012/10/31 面试题
物理专业大学生职业生涯规划书
2014/02/07 职场文书
幼儿园亲子活动总结
2014/04/26 职场文书
《闻一多先生的说和做》教学反思
2014/04/28 职场文书
分公司总经理岗位职责
2014/07/30 职场文书
单位接收证明格式
2015/06/18 职场文书
2016入党积极分子心得体会
2016/01/06 职场文书
2016教师廉洁教育心得体会
2016/01/13 职场文书
建立共青团委员会的请示
2019/04/02 职场文书
CSS3实现的3D隧道效果
2021/04/27 HTML / CSS
vue打包时去掉所有的console.log
2022/04/10 Vue.js