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生成便于打印的网页
Oct 09 PHP
php对gzip文件或者字符串解压实例参考
Jul 25 PHP
PHP安全配置详细说明
Sep 26 PHP
ThinkPHP分页类使用详解
Mar 05 PHP
thinkphp使用phpmailer发送邮件的方法
Nov 24 PHP
PHP中is_file()函数使用指南
May 08 PHP
php基础设计模式大全(注册树模式、工厂模式、单列模式)
Aug 31 PHP
jquery+thinkphp实现跨域抓取数据的方法
Oct 15 PHP
PHP钩子与简单分发方式实例分析
Sep 04 PHP
php大小写转换函数(strtolower、strtoupper)用法介绍
Nov 17 PHP
详解php与ethereum客户端交互
Apr 28 PHP
windows环境下使用Composer安装ThinkPHP5
May 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
让你的WINDOWS同时支持MYSQL4,MYSQL4.1,MYSQL5X
2006/12/06 PHP
destoon实现调用热门关键字的方法
2014/07/15 PHP
php实现的mongodb操作类实例
2015/04/03 PHP
PHP实现验证码校验功能
2017/11/16 PHP
Laravel使用原生sql语句并调用的方法
2019/10/09 PHP
点击文章内容处弹出页面代码
2009/10/01 Javascript
javascript 词法作用域和闭包分析说明
2010/08/12 Javascript
js实现文本框中焦点在最后位置
2014/03/04 Javascript
正则表达式(语法篇推荐)
2016/06/24 Javascript
Angular和Vue双向数据绑定的实现原理(重点是vue的双向绑定)
2016/11/22 Javascript
JS及JQuery对Html内容编码,Html转义
2017/02/17 Javascript
JS实现字符串中去除指定子字符串方法分析
2018/05/17 Javascript
Vue2.0学习系列之项目上线的方法步骤(图文)
2018/09/25 Javascript
详解vue组件中使用路由方法
2019/02/12 Javascript
教你如何用Node实现API的转发(某音乐)
2019/09/20 Javascript
vue实现PC端分辨率适配操作
2020/08/03 Javascript
python实现TCP服务器端与客户端的方法详解
2015/04/30 Python
Python检测QQ在线状态的方法
2015/05/09 Python
简单谈谈python中的语句和语法
2017/08/10 Python
Python3.4实现从HTTP代理网站批量获取代理并筛选的方法示例
2017/09/26 Python
初探TensorFLow从文件读取图片的四种方式
2018/02/06 Python
Python 3.6 读取并操作文件内容的实例
2018/04/23 Python
目前最全的python的就业方向
2018/06/05 Python
Python实现动态给类和对象添加属性和方法操作示例
2020/02/29 Python
Window系统下Python如何安装OpenCV库
2020/03/05 Python
在Django中预防CSRF攻击的操作
2020/03/13 Python
把Anaconda中的环境导入到Pycharm里面的方法步骤
2020/10/30 Python
django inspectdb 操作已有数据库数据的使用步骤
2021/02/07 Python
水上运动奥特莱斯:Wasterports Outlet
2018/08/08 全球购物
大学毕业通用个人的求职信
2013/12/08 职场文书
财务部出纳岗位职责
2013/12/22 职场文书
群众路线调研报告范文
2014/11/03 职场文书
2015年超市工作总结范文
2015/05/26 职场文书
pycharm部署django项目到云服务器的详细流程
2021/06/29 Python
hive数据仓库新增字段方法
2022/06/25 数据库