中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

c++中怎么實現一個哈希慢算法

發布時間:2021-08-07 15:45:38 來源:億速云 閱讀:168 作者:Leah 欄目:編程語言

c++中怎么實現一個哈希慢算法,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

首先,我定義了一個哈夫曼樹結點:

class hNode
{
 public:
  friend bool operator > (hNode n1,hNode n2); //定義了大于符號,供優先隊列排列使用
  hNode(string d="",int i=0,hNode* l = NULL,hNode* r =NULL):left(l),right(r),data(d),value(i){} 
  hNode* left;
  hNode* right;
  string data; //儲存的字符串
  int value; //字符串出現的次數
};
bool operator >(hNode n1,hNode n2)
{
 return n1.value > n2.value;
}

初步的設想是這樣的,先把所有的hNode對象都壓入優先隊列中去,然后每次彈出兩個,組成一個新的結點,再把新的結點壓入隊列,重復這一步驟,當隊列中只有一個元素時,哈夫曼樹也就完成了。像這樣:(是錯的,可別學)

while(...)
{
 std::priority_queue<hNode> q;
 .....
 hNode h2 = q.top();
 q.pop();
 hNode h3 = q.top();
 q.pop();
 hNode r;
 r.left = h2;
 r.right = h3;
 r.value = h2.value + h3.value;
}

然而遭遇的第一個問題是,STL的所有容器的的插入都是基于by value語義的,也就是要生成一個對象的副本放在容器中。這樣的后果就是hNode的left,right指針都指到不知道什么地方去了。大家可以稍微畫幾個圖試一下,就知道出了什么問題了。考慮一下后,發現如果隊列里存放hNode的指針,就不會出現這個問題了,于是改寫成:

hNode* makeTree(priority_queue<hNode*> pq)
{
 hNode* p1 = NULL;
 hNode* p2 = NULL;
 hNode* r = NULL;
 while( !pq.empty())
 {
  p1 = pq.top();
  pq.pop();
  if (pq.empty()) 
  {
   r = p1;
   return r;
  }
  p2 = pq.top();
  pq.pop();
  r =new hNode;
  r->left = p1;
  r->right = p2;
  r->value = p1->value +p2->value;
  pq.push(r);
 }
 return NULL;
}

然而馬上遭遇了第二個問題。std::priority_queue在判斷優先關系的時候,直接比較指針的地址,而不是指針指向的對象的大小關系。而指針不是類,我沒辦法重寫指針的比較操作。程序陷入了困境之中。std::priority_queue默認使用Greater<>模板來生成一個function object來對元素進行比較,我試圖為Greater<>寫一個hNode*的特化版本來改變優先隊列對hNode*的比較,然而也沒有成功。山重水復疑無路之時,突然想到為什么不直接為優先隊列寫一個function object來替代Greater<>不就可以了嗎?趕快寫下如下代碼:

struct phNodeComp
{
 bool operator () (const hNode*& left,const hNode*& right) const
 {
  return left->value > right->value;
 }
};

然后把std::priority_queue的申明變為:

priority_queue<hNode*,vector<hNode*>,phNodeComp > pq;

看完上述內容,你們掌握c++中怎么實現一個哈希慢算法的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

新晃| 四会市| 宜良县| 磐石市| 黄冈市| 天门市| 封开县| 夏邑县| 仁化县| 五华县| 鄂托克旗| 唐海县| 洛南县| 美姑县| 横峰县| 旅游| 卫辉市| 中阳县| 台江县| 阿鲁科尔沁旗| 昌平区| 霍邱县| 营山县| 高陵县| 木里| 宜昌市| 遂平县| 五家渠市| 怀远县| 黑山县| 嘉峪关市| 双牌县| 合山市| 南丹县| 昆山市| 特克斯县| 禹州市| 基隆市| 瑞金市| 彰化县| 京山县|