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 相关文章推荐
第八节--访问方式
Nov 16 PHP
用PHP函数解决SQL injection
Dec 09 PHP
php 高效率写法 推荐
Feb 21 PHP
js和php邮箱地址验证的实现方法
Jan 09 PHP
smarty模板局部缓存方法使用示例
Jun 17 PHP
两个php日期控制类实例
Dec 09 PHP
PHP中$_SERVER使用说明
Jul 05 PHP
PHP实现获取某个月份周次信息的方法
Aug 11 PHP
盘点PHP和ASP.NET的10大对比!
Dec 24 PHP
php实现批量上传数据到数据库(.csv格式)的案例
Jun 18 PHP
Thinkphp5框架实现图片、音频和视频文件的上传功能详解
Aug 27 PHP
在TP5数据库中四个字段实现无限分类的示例
Oct 18 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个人网站架设连环讲(三)
2006/10/09 PHP
php+mysql查询优化简单实例
2015/01/13 PHP
javascript对象之内置对象Math使用方法
2010/04/16 Javascript
JavaScript高级程序设计(第3版)学习笔记13 ECMAScript5新特性
2012/10/11 Javascript
如何从jQuery的ajax请求中删除X-Requested-With
2013/12/11 Javascript
浅析node.js中close事件
2014/11/26 Javascript
js实现每日自动换一张图片的方法
2015/05/04 Javascript
IE9+已经不对document.createElement向下兼容的解决方法
2015/09/14 Javascript
jquery单击事件和双击事件冲突解决方案
2016/03/02 Javascript
JavaScript基础重点(必看)
2016/07/09 Javascript
JavaScript 深层克隆对象详解及实例
2016/11/03 Javascript
JavaScript获取服务器端时间的方法
2016/11/29 Javascript
JS求解三元一次方程组值的方法
2017/01/03 Javascript
JavaScript实现音乐自动切换和轮播
2017/11/05 Javascript
JavaScript设计模式之单例模式简单实例教程
2018/07/02 Javascript
详解redux异步操作实践
2018/08/15 Javascript
微信小程序实现留言功能
2018/10/31 Javascript
弱类型语言javascript开发中的一些坑实例小结【变量、函数、数组、对象、作用域等】
2019/08/07 Javascript
[44:47]Ti4 循环赛第三日 iG vs NaVi
2014/07/12 DOTA
Python生成随机数的方法
2014/01/14 Python
Python中针对函数处理的特殊方法
2014/03/06 Python
python比较两个列表大小的方法
2015/07/11 Python
Python基础教程之tcp socket编程详解及简单实例
2017/02/23 Python
Python使用re模块实现信息筛选的方法
2018/04/29 Python
Python实现快速傅里叶变换的方法(FFT)
2018/07/21 Python
Python二叉树的遍历操作示例【前序遍历,中序遍历,后序遍历,层序遍历】
2018/12/24 Python
python实现两个dict合并与计算操作示例
2019/07/01 Python
python垃圾回收机制(GC)原理解析
2019/12/30 Python
Django实现后台上传并显示图片功能
2020/05/29 Python
伊莱克斯阿根廷网上商店:Tienda Electrolux
2021/03/08 全球购物
平面设计师的工作职责
2013/11/21 职场文书
领导视察欢迎词
2014/01/15 职场文书
小城镇建设汇报材料
2014/08/16 职场文书
2015年学习部工作总结范文
2015/03/31 职场文书
幼儿教师远程研修感悟
2015/11/18 职场文书
新手初学Java List 接口
2021/07/07 Java/Android