当前位置:Gxlcms > PHP教程 > PHP中使用BigMap实例,PHP使用BigMap实例_PHP教程

PHP中使用BigMap实例,PHP使用BigMap实例_PHP教程

时间:2021-07-01 10:21:17 帮助过:13人阅读

PHP中使用BigMap实例,PHP使用BigMap实例


  1. <?php
  2. //所谓的Bit-map就是用一个bit位来标记某个元素对应的Value, 而Key即是该元素。由于采用了Bit为单位来存储数据,因此在存储空间方面,可以大大节省。
  3. /*
  4. 若 N =1 ; 申请内存空间为 int a[2] ;
  5. 假设需要排序或者查找的总数N=10000000,那么我们需要申请内存空间的大小为int a[1 + N/32],其中:a[0]在内存中占32为可以对应十进制数0-31,依次类推:
  6. 1.求十进制0-N对应在数组a中的下标: n/32
  7. 2.求0-N对应0-31中的数: N%32=M
  8. 3.利用移位0-31使得对应32bit位为1: 1<<m,并置1; 举例="" :="" 如果想存储="" 3="" (1)="" a下标="" 30="" 32="0" ;="" 放在a[0]="" 中;="" (2)="" 3%="" (3)="" 左移="" 位="" 01000000="" 00000000="" 这个对应的值$a[0]="1073741824" 1.求十进制0-n对应在数组a中的下标:="" 十进制0-31,对应在a[0]中,先由十进制数n转换为与32的余可转化为对应在数组a中的下标。比如n="24,那么" n="" 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" $bitsperword="32" 移位的位数为5="" pow(2,5)="32" $shift="5" 存储数据的数组="" public="" $bitarray="array();" **="" $i="" 对应的数归零="" function="" clearbit($i){="" 则将当前byte中的指定bit位取0,&后其他对方数组bit位必然不变,这就是="" 1="" 的妙用="">>SHIFT 这里相当于 intval($i /32) ;
  9. // $i & $this->mask 这里相当于 $i % $this->mask ,取余
  10. @$this->bitArray[$i >> $this->shift] &= ~(1<<($i & $this->mask));
  11. }
  12. /**
  13. $i 对应的数致1
  14. */
  15. function setbit($i){
  16. @$this->bitArray[$i >> $this->shift] |= (1<<($i & $this->mask));
  17. }
  18. //test 测试所在的bit为是否为1
  19. function testbit($i){
  20. return $this->bitArray[$i >> $this->shift] & (1<<($i & $this->mask));
  21. }
  22. }
  23. $oBig = new bigMap() ;
  24. $oBig->setbit(30) ;
  25. var_dump($oBig->testbit(2)) ;
  26. var_dump($oBig->bitArray) ;
  27. echo decbin($oBig->bitArray[0]),"<br>";
  28. </m,并置1;>

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/976029.htmlTechArticlePHP中使用BigMap实例,PHP使用BigMap实例 php//所谓的Bit-map就是用一个bit位来标记某个元素对应的Value, 而Key即是该元素。由于采用了Bit为单位来...

人气教程排行