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

溫馨提示×

溫馨提示×

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

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

c++基于size和rank并查集優化是怎樣的

發布時間:2021-10-15 15:33:08 來源:億速云 閱讀:173 作者:柒染 欄目:編程語言

這篇文章將為大家詳細講解有關c++基于size和rank并查集優化是怎樣的,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

基于size的優化是指:當我們在指定由誰連接誰的時候,size數組維護的是當前集合中元素的個數,讓數據少的指向數據多的集合中

基于rank的優化是指:當我們在指定由誰連接誰的時候,rank數組維護的是當前集合中樹的高度,讓高度低的集合指向高度高的集合

運行時間是差不多的:

基于size的代碼: UnionFind3.h

#ifndef UNION_FIND3_H_#define UNION_FIND3_H_#include<iostream>#include<cassert>namespace UF3{class UnionFind{private:int* parent;int* sz;  //sz[i]就表示以i為根的集合中元素的個數int count;public:UnionFind(int count){this->count = count;parent = new int[count]; sz = new int[count];for(int i = 0 ; i < count ; i++){parent[i] = i;sz[i] = 1;}}~UnionFind(){delete [] parent;delete [] sz;}int find(int p){assert(p < count && p >= 0); while( p != parent[p]) //這個是寫到find里面的{p = parent[p];}return p;}void unionElements(int p , int q){int pRoot = find(p);int qRoot = find(q);if( pRoot == qRoot)return;if(sz[pRoot] < sz[qRoot]){parent[pRoot] = qRoot;sz[qRoot] += sz[pRoot];}else{parent[qRoot] = pRoot;sz[pRoot] += sz[qRoot];}}bool isConnected(int p , int q){return find(p) == find(q);}};};#endif

基于rank的代碼: UnionFind4.h

#ifndef UNION_FIND4_H_#define UNION_FIND4_H_#include<iostream>#include<cassert>namespace UF4{class UnionFind{private:int* parent;int* rank;  //rank[i]就表示以i為根的集合的層數int count;public:UnionFind(int count){this->count = count;parent = new int[count]; rank = new int[count];for(int i = 0 ; i < count ; i++){parent[i] = i;rank[i] = 1;}}~UnionFind(){delete [] parent;delete [] rank;}int find(int p){assert(p < count && p >= 0); while( p != parent[p]) //這個是寫到find里面的{p = parent[p];}return p;}void unionElements(int p , int q){int pRoot = find(p);int qRoot = find(q);if( pRoot == qRoot)return;if(rank[pRoot] < rank[qRoot]){parent[pRoot] = qRoot;}else if( rank[pRoot] > rank[qRoot] ){parent[qRoot] = pRoot;}else{parent[pRoot] = qRoot; //這里誰指向誰無所謂rank[qRoot] ++;}}bool isConnected(int p , int q){return find(p) == find(q);}};};#endif

關于c++基于size和rank并查集優化是怎樣的就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

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

AI

浦县| 新巴尔虎左旗| 吐鲁番市| 惠安县| 丹寨县| 额敏县| 吉木萨尔县| 龙江县| 伊春市| 大关县| 临桂县| 新泰市| 抚宁县| 五指山市| 礼泉县| 金川县| 鄂州市| 永年县| 辰溪县| 陕西省| 泰和县| 惠来县| 精河县| 信丰县| 蕲春县| 佛冈县| 社会| 山西省| 景宁| 荔波县| 中山市| 诸暨市| 宁都县| 南投市| 兴文县| 万州区| 儋州市| 常熟市| 白城市| 黄龙县| 定兴县|