国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

PHP中使用BigMap實(shí)例

2024-05-04 21:55:57
字體:
供稿:網(wǎng)友

 這篇文章主要介紹了PHP中使用BigMap實(shí)例,本文直接給出實(shí)現(xiàn)代碼,代碼中包含詳細(xì)注釋,需要的朋友可以參考

  1. <?php 
  2. //所謂的Bit-map就是用一個(gè)bit位來標(biāo)記某個(gè)元素對(duì)應(yīng)的Value, 而Key即是該元素。由于采用了Bit為單位來存儲(chǔ)數(shù)據(jù),因此在存儲(chǔ)空間方面,可以大大節(jié)省。 
  3.   
  4. /* 
  5.   
  6. 若 N =1 ; 申請(qǐng)內(nèi)存空間為 int a[2] ;  
  7. 假設(shè)需要排序或者查找的總數(shù)N=10000000,那么我們需要申請(qǐng)內(nèi)存空間的大小為int a[1 + N/32],其中:a[0]在內(nèi)存中占32為可以對(duì)應(yīng)十進(jìn)制數(shù)0-31,依次類推:  
  8.   
  9. 1.求十進(jìn)制0-N對(duì)應(yīng)在數(shù)組a中的下標(biāo): n/32  
  10.   
  11. 2.求0-N對(duì)應(yīng)0-31中的數(shù): N%32=M 
  12.   
  13. 3.利用移位0-31使得對(duì)應(yīng)32bit位為1: 1<<M,并置1; 
  14.   
  15. 舉例 :  
  16.   
  17. 如果想存儲(chǔ) 3  
  18. (1) a下標(biāo) 30/ 32 = 0 ; 放在a[0] 中;  
  19. (2) 3% 32 = 30;  
  20. (3) 左移 30 位 01000000 00000000 00000000 00000000 這個(gè)對(duì)應(yīng)的值$a[0] = 1073741824 ;  
  21.   
  22.   
  23. 1.求十進(jìn)制0-N對(duì)應(yīng)在數(shù)組a中的下標(biāo):  
  24. 十進(jìn)制0-31,對(duì)應(yīng)在a[0]中,先由十進(jìn)制數(shù)n轉(zhuǎn)換為與32的余可轉(zhuǎn)化為對(duì)應(yīng)在數(shù)組a中的下標(biāo)。比如n=24,那么 n/32=0,則24對(duì)應(yīng)在數(shù)組a中的下標(biāo)為0。又比如n=60,那么n/32=1,則60對(duì)應(yīng)在數(shù)組a中的下標(biāo)為1,同理可以計(jì)算0-N在數(shù)組a中的下標(biāo)。  
  25.   
  26. 2.求0-N對(duì)應(yīng)0-31中的數(shù):  
  27.   
  28. 十進(jìn)制0-31就對(duì)應(yīng)0-31,而32-63則對(duì)應(yīng)也是0-31,即給定一個(gè)數(shù)n可以通過模32求得對(duì)應(yīng)0-31中的數(shù)。  
  29.   
  30. 3.利用移位0-31使得對(duì)應(yīng)32bit位為1.  
  31.   
  32. 找到對(duì)應(yīng)0-31的數(shù)為M, 左移M位:即2^M. 然后置1. 
  33.   
  34.  由此我們計(jì)算10000000個(gè)bit占用的空間: 
  35.   
  36. 1byte = 8bit 
  37.   
  38. 1kb = 1024byte 
  39.   
  40. 1mb = 1024kb 
  41. 占用的空間為:10000000/8/1024/1024mb。 
  42.   
  43. 大概為1mb多一些。 
  44.    
  45.  */ 
  46.    
  47.  class bigMap { 
  48.      //使用兩個(gè)字節(jié)保存  
  49.     private $mask = 0x1f ; 
  50.     private $bitsperword = 32 ; 
  51.     // 移位的位數(shù)為5 pow(2,5) = 32  
  52.     private $shift = 5 ; 
  53.     // 存儲(chǔ)數(shù)據(jù)的數(shù)組  
  54.      public $bitArray = array();  
  55.    
  56.      /** 
  57.      $i 對(duì)應(yīng)的數(shù)歸零  
  58.      */ 
  59.      function clearbit($i){ 
  60.          ////則將當(dāng)前byte中的指定bit位取0,&后其他對(duì)方數(shù)組bit位必然不變,這就是 1 的妙用 
  61.          // $i>>SHIFT 這里相當(dāng)于 intval($i /32) ; 
  62.          // $i & $this->mask 這里相當(dāng)于 $i % $this->mask ,取余 
  63.          @$this->bitArray[$i >> $this->shift] &= ~(1<<($i & $this->mask));  
  64.     } 
  65.    
  66.      /** 
  67.      $i 對(duì)應(yīng)的數(shù)致1  
  68.      */ 
  69.      function setbit($i){ 
  70.          @$this->bitArray[$i >> $this->shift] |= (1<<($i & $this->mask));  
  71.     } 
  72.    
  73.  //test 測(cè)試所在的bit為是否為1  
  74.  function testbit($i){  
  75.         return $this->bitArray[$i >> $this->shift] & (1<<($i & $this->mask));  
  76.     }     
  77.  } 
  78.   
  79.   
  80. $oBig = new bigMap() ;  
  81.   
  82. $oBig->setbit(30) ;  
  83.   
  84. var_dump($oBig->testbit(2)) ;  
  85. var_dump($oBig->bitArray) ;  
  86.   
  87. echo decbin($oBig->bitArray[0]),"<br>";  

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 伊吾县| 庆安县| 岳阳市| 五大连池市| 咸阳市| 麻城市| 精河县| 康保县| 威宁| 项城市| 平顺县| 鸡西市| 都昌县| 蒙自县| 大方县| 阳江市| 谷城县| 正蓝旗| 康马县| 昌图县| 武定县| 许昌市| 永济市| 广平县| 徐汇区| 赞皇县| 休宁县| 五台县| 庄河市| 从化市| 望城县| 蓬溪县| 远安县| 比如县| 枣阳市| 黎城县| 顺昌县| 天全县| 三都| 吉木萨尔县| 建平县|