• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

PHP中使用BigMap实例

php 搞代码 4年前 (2022-01-21) 14次浏览 已收录 0个评论

这篇文章主要介绍了PHP中使用BigMap实例,本文直接给出实现代码,代码中包含详细注释,需要的朋友可以参考下

<?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=M3.利用移位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 这个对<strong style="color:transparent">本文来源gao@daima#com搞(%代@#码@网&</strong><strong>搞gaodaima代码</strong>应的值$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 = 8bit1kb = 1024byte1mb = 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编程从入门到精通全套视频教程


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:PHP中使用BigMap实例
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址