java并查集找朋友圈_圖—并查集(解決朋友圈問題)

圖也是一種 非線性結構,是由多個頂點組成的關系集合組成的一種數據結構。圖可以分為兩種,無向圖和有向圖。

★圖的定義:

75e3ecc5695baa1f49784db4e3c1368b.png

★典型問題:

利用圖能夠解決很多問題,這里有一個較為典型的問題,假如已知有n個人和m對好友關系(存于數字r)。如果兩個人是直接或者間接的好友(即就是好友的好友...),則認為他們屬于一個朋友圈,請寫出程序求出這n個人里一共有多少個朋友圈。

例如:n = 5, m = 3, r = {{1,2},{2,3},{4,5}}, 表示有5個人,1和2是朋友,2和3也是朋友,4和5是朋友,則1,2,3屬于一個朋友圈,4、5屬于另一個朋友圈,結果為2個朋友圈。

★解題思路:

首先,先介紹一個概念:并查集。并查集就是將N個不同元素分成一組不想交的集合,開始時,每個元素就是一個集合,然后按規律將兩個集合進行合并。具體的做法如下:

設定一個有N個元素的數組,將每個元素對應的位置都置為-1,即就是先讓其沒有相交,然后根據題目中給出的朋友關系,將根節點元素對應的位置減1,將與根節點是好友的元素對應的位置更改為根節點元素,按照這樣的方式,將所有的關系都進行對應,最后數組中如果是負數,所對應的元素就是根節點。

aba097f2cd81005e8ebcae12b8bef5a8.png

★具體代碼:#pragma?once

#include?

//實現圖??——并查集

/*

主要功能:給定一個范圍,能夠確定朋友圈的個數

*/

class?UnionFindSet

{

public:

UnionFindSet(size_t?size)????//構造函數

:_n(size)

,?_set(new?int[size])

{

for?(int?i?=?0;?i?

{

_set[i]?=?-1;

}

}

void?Union(int?root1,?int?root2)????//結合兩個根節點

{

assert(_set[root1]?

assert(_set[root2]?

_set[root1]?+=?_set[root2];

_set[root2]?=?root1;

}

size_t?FindRoot(int?child)

{

if?(_set[child]?

{

return?child;

}

int?num?=?_set[child];

while?(num?>=?0)

{

num?=?_set[num];

}

return?num;

}

void?print()

{

int?root?=?0;

for?(int?i?=?0;?i?

{

if?(_set[i]?

{

root++;

}

}

cout?<

}

protected:

int*?_set;????//數組指針

size_t?_n;?????//給定范圍數據的個數

};

void?Test()

{

UnionFindSet?ht(10);

ht.Union(0,?6);

ht.Union(0,?7);

ht.Union(0,?8);

ht.Union(1,?4);

ht.Union(1,?9);

ht.Union(2,?3);

ht.Union(2,?5);

ht.print();

}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/453477.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/453477.shtml
英文地址,請注明出處:http://en.pswp.cn/news/453477.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

技術這東西,不可不看,不可全看.

最近忙著玩開心,好久沒來CSDN了,首頁上有90后程序員的消息了,稍微感慨一下,曾幾何時,自己這個80后還被70后的前輩所笑話,轉眼就成了5年經驗的老油條了.呵呵. 5年,個人認為經歷還是有些代表性的,就跟剛入行或者即將入行的哥們交個底吧,這5年到底學到了什么. 如果你看完這篇文…

rand.nextint()

自從JDK最初版本發布起&#xff0c;我們就可以使用java.util.Random類產生隨機數了。在JDK1.2中&#xff0c;Random類有了一個名為nextInt()的方法&#xff1a;public int nextInt(int n)給定一個參數n&#xff0c;nextInt(n)將返回一個大于等于0小于n的隨機數&#xff0c;即&a…

Android開發常用的插件及工具

1、GitHub,這個不管是做安卓還是其他&#xff0c;只要是開發就必上的網站&#xff0c;也是天朝沒有墻掉為數不多的網站 2、Stack OverFlow,這個和上面一樣&#xff0c;國外非常著名的問答網站&#xff0c;在上面基本上很多問題都可以得到解決 3、Genymotion模擬器&#xff0c;搞…

java poi 設置標題_poi生成Word時指定文本樣式,如“正文”,“標題1”,“標題2”等...

POI生成Word時&#xff0c;設置段落的樣式String style "2"; //標題2的樣式XWPFParagraph xwpfParagraph doc.insertNewParagraph(run);xwpfParagraph.setStyle(style);其實設置其他的樣式都一樣。例如&#xff1a;你想設置你的樣式為“標題2”(“標題2”只是你在w…

使用python做最簡單的爬蟲

使用python做最簡單的爬蟲 --之心 #第一種方法import urllib2 #將urllib2庫引用進來responseurllib2.urlopen("http://www.baidu.com") #調用庫中的方法&#xff0c;將請求回應封裝到response對象中htmlresponse.read() #調用response對象的read&#xff08;&#x…

SurfaceView介紹

SurfaceView介紹 通常情況程序的View和用戶響應都是在同一個線程中處理的&#xff0c;這也是為什么處理長時間事件&#xff08;例如訪問網絡&#xff09;需要放到另外的線程中去&#xff08;防止阻塞當前UI線程的操作和繪制&#xff09;。但是在其他線程中卻不能修改UI元素&…

產品與市場,究竟哪一個重要

上篇我們講到B2C繼B2B和C2C紅透之后&#xff0c;也正在迅速的竄紅。這一看法可不是我老邢杜撰&#xff0c;憑空想出來的&#xff0c;我們也可以從近期的主要媒體雜志上看到這個彌端。《二十一世紀報道》、《創業家》、《市場與營銷》這些經濟類雜志&#xff0c;均用大幅篇幅甚至…

enumerate()使用

enumerate()使用 如果對一個列表&#xff0c;既要遍歷索引又要遍歷元素時&#xff0c;首先可以這樣寫&#xff1a; list1 ["這", "是", "一個", "測試"] for i in range (len(list1)): print i ,list1[i] 上述方法有些累贅&#xff0…

php在window,php在window上的問題

C:/php-7/php-cgi.exe -b 127.0.0.1:9000 -c C:/php-7/php.ini用以上方式打開php的話&#xff0c;會自動的關閉&#xff0c;到處查了后說什么東西默認是500次&#xff0c;到了的話cgi就會關閉所以才想到用以下的批處理辦法去解決echo offecho Starting PHP FastCGI...set PHP_F…

(三)SpringBoot之配置文件詳解:Properties和YAML

一、配置文件的生效順序&#xff0c;會對值進行覆蓋&#xff1a; 1. TestPropertySource 注解2. 命令行參數3. Java系統屬性&#xff08;System.getProperties()&#xff09;4. 操作系統環境變量5. 只有在random.*里包含的屬性會產生一個RandomValuePropertySource6. 在打包的j…

fscanf()php,fscanf函數的用法

以前解析有規律的文件的時候要么用正則表達式&#xff0c;要么就是傻傻的自己寫程序來解析有規律的文件。今天突然發現c的庫函數中有一個現成的可以解析有規律的文件的函數&#xff0c;就是fscanf()函數。fscanf 位于頭文件中&#xff0c;函數原型為 int fscanf(FILE * stream,…

ComponentName知識

以下是ComponentName的API /*** Create a new component identifier from a Context and Class object.* * param pkg A Context for the package implementing the component, from* which the actual package name will be retrieved.* param cls The Class object of the de…

為什么設計師應該學習編寫代碼

通常&#xff0c;在完成了一件網頁設計后&#xff0c;設計師的無知都會顯露無遺而備受指責。他們把創建網頁代碼的繁重工作都留給了程序員們。這種現象不只出現在網絡開發行業&#xff0c;在軟件及游戲開發業也是如此&#xff08;完整圖文版&#xff09;。殘酷的事實就是&#…

unittest核心要素

1 TestCase 一個TestCase的實例就是一個測試用例。什么是測試用例呢&#xff1f;就是一個完整的測試流程&#xff0c; 包括測試環境的準備(setUp)&#xff0c;執行測試代碼(run)&#xff0c;以及測試后環境的還原&#xff08;tearDown&#xff09;。單元 測試&#xff08;unit …

iOS內存區域部分內容

目前參考這里&#xff1a; https://www.zhihu.com/question/263823072/answer/273452932 以后整理相關的代碼問題。 更多參考資料&#xff1a; https://stackoverflow.com/questions/79923/what-and-where-are-the-stack-and-heap 堆棧&#xff1a;https://baike.baidu.com/ite…

php 啟動ffmpeg,安裝php擴展 ffmpeg-php

首先先下載擴展包擴展下載地址: http://nchc.dl.sourceforge.net/project/ffmpeg-php/ffmpeg-php/0.6.0/ffmpeg-php-0.6.0.tbz2進入 ffmpeg-php目錄 進行編譯擴展/usr/local/php/bin/phpize./configure --with-php-config/usr/local/php/bin/php-configmake 出錯報錯情況make: …

armeabi和armeabi-v7a的區別

armeabi默認選項&#xff0c; 支持基于 ARM* v5TE 的設備 支持軟浮點運算&#xff08;不支持硬件輔助的浮點計算&#xff09; 支持所有 ARM* 設備 armeabi-v7a 支持基于 ARM* v7 的設備 支持硬件 FPU 指令 支持硬件浮點運算 不同手機由于cpu的不同&#xff0c;使用不同的驅動…

淺析Numpy.genfromtxt及File I/O講解

Python 并沒有提供數組功能&#xff0c;雖然列表 (list) 可以完成基本的數組功能&#xff0c;但它并不是真正的數組&#xff0c;而且在數據量較大時&#xff0c;使用列表的速度就會慢的讓人難受。為此&#xff0c;Numpy 提供了真正的數組功能&#xff0c;以及對數據快速處理的函…

麻雀雖小,五臟俱全:分析CVS活動情況的小工具(有源碼供學習)

最近開發團隊發布的版本質量很成問題&#xff0c;追究起來有很多原因&#xff0c;其中之一是CVS的使用不合理&#xff0c; 于是想做個一小工具&#xff0c;分析CVS上每天的活動&#xff0c;以便掌握團隊成員對CVS的使用情況。 也許有現成的開源項目可以完成這項任務&#xff…

php如果實現日歷的制作,教大家制作簡單的php日歷

最近的一個項目中&#xff0c;需要將數據用日歷方式顯示&#xff0c;網上有很多的JS插件&#xff0c;后面為了自己能有更大的控制權&#xff0c;決定自己制作一個日歷顯示。如下圖所示&#xff1a;一、計算數據1、new一個Calendar類2、初始化兩個下拉框中的數據&#xff0c;年份…