亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? p372.cpp

?? 殷人昆 數據結構 一些書中的源代碼 系某師兄所做 c++版
?? CPP
字號:
		int IsPrime ( int N ) {					//測試N是否質數
		   for ( int i=3; i*i<=N; i+=2 )				//若N能分解為兩個整數的乘積, 其中一個一定 
			 if ( N % i == 0 ) return 0;			//N能整除i, N不是質數
		   return 1;							//N是質數
		}

		int NextPrime ( int N ) {					//求下一個>N的質數,設N >= 5
		   if ( N % 2 == 0 ) N++;				//偶數不是質數
		   for ( ; !IsPrime (N); N+=2 );				//尋找質數
		   return N;
		}

		template <class Type> class HashTable {				//散列表類的定義
		public:
		   enum KindOfEntry { Active, Empty, Deleted };			//表項分類 (活動 / 空 / 刪)
		   int Find ( const Type & x );				//在散列表中搜索x
		   int IsEmpty ( ) { return !CurrentSize ? 1 : 0; }			//判散列表空否,空則返回1 
		   int IsFull ( ) { return CurrentSize == TableSize ? 1 : 0; }	//判散列表滿否,滿則返回1
		   int Insert ( const Type & x );
		   int Remove ( const Type & x );
		   int IsIn ( const Type & x );
		   int WasFound ( ) const { return LastFindOK;	}		//判最近一次搜索是否成功
		   //其它共有函數與定義10.6聲明線性探查散列表類相同
		   HashTable ( int sz=DefaultSize ) : TableSize ( sz ) { AllocateHt ( );  CurrentSize = 0; }		//構造函數
		   ~HashTable ( ) { delete [ ] ht; }						//析構函數
		   const HashTable & operator = ( const HashTable & ht2 );		//重載函數:表賦值
		   int FindPos ( const Type & x ); 					//散列函數: 計算含x表項的初始桶號
		   void MakeEmpty ( );								//置散列表為空

		private:
		   struct HashEntry {							//散列表的表項定義
		      Type Element;							//表項的數據, 即表項的關鍵碼
		      KindOfEntry info;							//三種狀態: Active, Empty, Deleted
		      HashEntry ( ) : info (Empty ) { }					//表項構造函數
		      HashEntry ( const Type &E, KindOfEntry i = Empty ) : Element (E), info (i) { };
		   };
		   //enum { DefualtSize = 11; };
		   HashEntry *ht; 								//散列表存儲數組
		   int TableSize;								//數組長度,要求是滿足4k+3的質數,k是整數
		   int CurrentSize;								//已占據散列地址數目
		   int LastFindOK;							//若最近一次搜索成功成功, 則返回1
		   void AllocateHt ( ) { ht = new HashEntry[TableSize ]; }	//分配散列表存儲空間的函數
		};
		template <class Type> int HashTable<Type>::Find ( const Type & x ) {
		//共有函數: 找下一散列位置的函數
		   int i = 0,  odd = 0 ;								// i為探查次數,odd是控制加減標志
		   int CurrentPos = FindPos ( x );						//利用散列函數計算x的散列地址
		   while ( ht[CurrentPos].info != Empty && ht[CurrentPos].Element != x ) {	//搜索是否要求表項
			 if ( !odd ) {									// odd == 0為(H0 + i2)%TableSize情形
			   CurrentPos += 2*++i - 1;   odd = 1;				//求“下一個”桶
		 	   while ( CurrentPos >= TableSize ) CurrentPos -= TableSize;	//實現取模
			 }
			 else {										// odd == 1為(H0 - i2)%TableSize情形
			   CurrentPos -= 2*i-1;  odd = 0;					//求“下一個”桶
			   while ( CurrentPos < 0 ) CurrentPos += TableSize; 		//實現取模
			 }
		   }
		   LastFindOK = ht[CurrentPos].info == Active;				//記下最后是否搜索成功信息
		   return CurrentPos;								//返回桶號
		};

		template <class Type> int HashTable<Type>::Insert ( const Type & x ) {
		//將x插入到散列表中, 若x在表中已存在, 則返回0, 否則返回1。
		   int CurrentPos = Find (x);
		   if (LastFindOK ) return 0;						//該項在表中已經存在, 不再加入
		   ht[CurrentPos] = HashEntry ( x, Active );				//插入x
		   if ( ++CurrentSize < TableSize/2) return 1;				//當前已有項數加1, 不超過表長的一半返回
		   HashEntry *Oldht = ht;						//分裂空間處理: 保存原來的散列表
		   int OldTableSize = TableSize;
		   CurrentSize = 0;
		   TableSize = NextPrime ( 2 * OldTableSize );			//原表大小的2倍,取質數
		   AllocateHt ( );								//建立新的二倍大小的空表
		   for (int i=0; i<OldTableSize; i++)					//原來的元素重新散列到新表中
		      if ( Oldht[i].info == Active ) Insert ( Oldht[i].Element );	//遞歸調用
		   delete [ ] Oldht;
		   return 1;
		}

		template <class Type> int HashTable<Type>::IsIn ( const Type & x ) {
		//判斷x是否在散列表中。若在表中, 則返回1, 否則返回0。
		   int CurrentPos = Find ( x );
		   return LastFindOK;
		}

		template <class Type> int HashTable<Type>::Remove ( const Type & x ) {
		//將x從散列表中刪除。若刪除成功, 則返回1, 否則返回0。
		   int CurrentPos = Find (x);
		   if (!LastFindOK ) return 0;						//該項在散列表中沒有
		   ht[CurrentPos].info = Deleted;  return 1;				//作刪除標記, 刪除成功
		}



		//以下來自線性探查法
		template <class Type> void HashTable<Type>::MakeEmpty ( ) {		//清除散列表
		   for ( int i=0; i<TableSize; i++) ht[i].info = Empty;
		   CurrentSize = 0;
		}

		template <class Type> const HashTable<Type> & HashTable<Type>::operator= ( const HashTable<Type> &ht2 ) {
		//重載函數:復制一個散列表ht2
		   if ( this != &ht2 ) {
			 delete [ ] ht;  TableSize = ht2.TableSize;  AllocateHt ( );		//重新分配目標散列表存儲空間
			 for ( int i=0; i<TableSize; i++ ) ht[i] = ht2.ht[i];			//從源散列表向目標散列表傳送
			 CurrentSize = ht2.CurrentSize;						//傳送當前表項個數
		   }
		   return *this;									//返回目標散列表結構指針
		}
      

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆自制传媒国产之光| 亚洲欧洲av另类| 亚洲一二三级电影| 色婷婷av一区二区三区之一色屋| 日本一区二区不卡视频| 成人激情免费电影网址| 国产精品国产成人国产三级| www.亚洲激情.com| 亚洲国产另类av| 亚洲综合自拍偷拍| 91精选在线观看| 国产乱人伦精品一区二区在线观看 | 欧美精品在线一区二区三区| 久久99热这里只有精品| 国产精品电影院| 亚洲欧洲一区二区三区| 亚洲乱码国产乱码精品精小说 | 国产最新精品免费| 国产精品免费久久久久| 91精品蜜臀在线一区尤物| 91精品国产色综合久久不卡蜜臀 | 2014亚洲片线观看视频免费| av中文字幕不卡| 色婷婷狠狠综合| 欧美日本一道本在线视频| 精品中文av资源站在线观看| 亚洲日本va在线观看| 国产午夜精品在线观看| 欧美影院一区二区三区| 国内久久婷婷综合| 国产成人精品影视| 青青草97国产精品免费观看无弹窗版| 中文字幕乱码亚洲精品一区| 中文字幕日本乱码精品影院| 日精品一区二区| 一区二区在线观看免费视频播放| 午夜欧美一区二区三区在线播放| 17c精品麻豆一区二区免费| 亚洲一区二区在线视频| 亚洲日本丝袜连裤袜办公室| 亚洲成人一区在线| 亚洲国产成人高清精品| 国产精品一区一区| 欧美天堂亚洲电影院在线播放 | 亚洲一区二区三区激情| 国产一区二区三区高清播放| 日韩电影在线免费看| 亚洲va欧美va人人爽午夜| 国产真实乱偷精品视频免| 欧洲精品一区二区| 欧美日韩精品高清| 国产精品热久久久久夜色精品三区| 亚洲伦理在线精品| 懂色av一区二区三区免费看| 日本不卡高清视频| 欧美怡红院视频| 国产精品免费久久久久| 精品系列免费在线观看| 欧美一区二区大片| 中文字幕一区三区| 国产成人三级在线观看| 欧美一级精品大片| 国产婷婷色一区二区三区| 日韩成人伦理电影在线观看| 91蝌蚪porny| 中文字幕av一区 二区| 国产一区二区0| 精品国产三级电影在线观看| 国产亚洲自拍一区| 精品一区二区免费在线观看| 欧美一区二区福利在线| 日精品一区二区三区| 欧美在线观看视频一区二区三区| 亚洲天天做日日做天天谢日日欢| 国产风韵犹存在线视精品| 精品国产一区久久| 狠狠狠色丁香婷婷综合久久五月| 91精品国产综合久久小美女| 香蕉久久夜色精品国产使用方法| 在线一区二区视频| 91精品国产麻豆国产自产在线| 亚洲成人资源网| 欧美日韩一区二区三区在线| 久久精品一区二区三区四区| 精品在线免费观看| 久久久午夜电影| 亚洲444eee在线观看| 欧美日韩一区二区在线观看| 丝袜诱惑制服诱惑色一区在线观看| 在线免费观看不卡av| 亚洲大片在线观看| 7777精品伊人久久久大香线蕉| 日韩av在线发布| 欧美变态口味重另类| 亚洲成人免费av| 欧美一级免费大片| 国产一区二区中文字幕| 国产嫩草影院久久久久| 视频一区视频二区中文字幕| 91精品在线一区二区| 国产一区二区调教| 中文字幕在线一区免费| 欧美性欧美巨大黑白大战| 蜜桃一区二区三区在线观看| 精品视频色一区| 久久精品噜噜噜成人av农村| 亚洲乱码精品一二三四区日韩在线| 色综合久久久久| 亚洲不卡一区二区三区| 精品国产第一区二区三区观看体验| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 欧美精品视频www在线观看| 美女视频黄 久久| 国产精品电影一区二区三区| 欧美日韩日日骚| 国产在线播精品第三| 亚洲日本欧美天堂| 2024国产精品| 欧美日韩一区二区三区免费看 | 久久精品一区四区| 欧美日韩精品福利| 成人一区二区三区中文字幕| 欧美一区二区观看视频| 成人黄色国产精品网站大全在线免费观看| 亚洲一二三四在线观看| 欧美一区二区免费视频| 日本精品视频一区二区| 免费日韩伦理电影| 亚洲精品国产a久久久久久 | 日韩精品电影在线| 综合色天天鬼久久鬼色| 日韩精品专区在线影院重磅| 午夜免费久久看| 国产精品久久免费看| 欧美日韩国产区一| 91香蕉视频在线| 国产69精品久久久久毛片| 免费在线观看视频一区| 亚洲国产中文字幕在线视频综合| 中文字幕av一区二区三区免费看 | 成人黄色免费短视频| 久久精品国产亚洲5555| 一区二区国产盗摄色噜噜| 国产精品视频一区二区三区不卡| 欧美成人女星排行榜| 欧美精品高清视频| 欧美日韩在线播放| 欧美午夜宅男影院| 欧美在线啊v一区| 色综合久久中文字幕综合网| 成人精品高清在线| 国产成人福利片| 国产suv精品一区二区6| 国产成人日日夜夜| 国产成人亚洲精品狼色在线| 国内精品伊人久久久久av影院| 日本 国产 欧美色综合| 奇米888四色在线精品| 91麻豆精品国产91久久久久久久久| 一本色道综合亚洲| 色美美综合视频| 在线观看一区日韩| 欧洲精品在线观看| 欧美日韩免费观看一区三区| 精品视频在线看| 91精品国产欧美一区二区| 日韩视频在线观看一区二区| 精品少妇一区二区三区日产乱码 | 老司机免费视频一区二区 | 成人综合婷婷国产精品久久 | 日韩三级精品电影久久久| 日韩欧美第一区| 国产日韩精品视频一区| 中文字幕成人在线观看| 亚洲老司机在线| 丝袜亚洲另类欧美| 国产在线一区二区综合免费视频| 久久99国产精品麻豆| 粉嫩久久99精品久久久久久夜| 97se亚洲国产综合自在线观| 午夜精品成人在线视频| 蜜臀av性久久久久蜜臀av麻豆 | 国产网站一区二区三区| 国产精品久久久久久久午夜片 | 欧美精品乱人伦久久久久久| 91精品国产品国语在线不卡| 精品国产亚洲一区二区三区在线观看| 国产色产综合产在线视频| 综合久久一区二区三区| 日韩精品1区2区3区| 大胆欧美人体老妇| 制服丝袜中文字幕亚洲| 国产色综合久久| 日韩福利电影在线| 成人免费视频免费观看| 欧美日韩高清一区| 亚洲色图在线视频| 精品系列免费在线观看| 91福利区一区二区三区| 久久久久亚洲综合|