【秋招机试真题】华为机试0407-1-幼儿园小朋友分组
/*
*?? ?題目描述:
?? ??? ?幼兒園老師安排小朋友做游戲,現(xiàn)在需要給N個(gè)小朋友進(jìn)行分組,老師讓每個(gè)同學(xué)寫(xiě)一個(gè)名字,代表這位小朋友
?? ??? ?想和誰(shuí)分到一組,請(qǐng)問(wèn)老師在滿(mǎn)足所有小朋友意愿的情況下,最多可以將班級(jí)分成多少組?
?? ?輸入描述:
?? ??? ?第一行輸入N,0<N<=100000
?? ??? ?接下來(lái)的N行代表每個(gè)小朋友希望和誰(shuí)分到一組,如“John Jack”,代表John希望和Jack分到一組,兩個(gè)名字之間
?? ??? ?以空格分割,名字本身不存在空格
?? ?輸出描述:
?? ??? ?分組的最多數(shù)量
? ? ?示例:
? ? ? ? 輸入:
? ? ? ? 3
? ? ? ? Tom John
? ? ? ? John Jane
? ? ? ? Jane Tom
? ? ? ? 輸出:
? ? ? ? 1
*?? ?
說(shuō)明:華為0407第一題
考察知識(shí)點(diǎn):并查集
解題思路:
? ? ? ? 1、使用hash表建立每個(gè)小朋友的父節(jié)點(diǎn)關(guān)系表;
? ? ? ? 2、輸出有幾個(gè)連通圖
代碼如下:
#include<iostream> #include<unordered_map> #include<string> using namespace std; class UF { private:unordered_map<string, string> fri;//vector<string> fri;int circle; public:UF(int person_num) {circle = person_num;}void add(string s) {//fri.push_back(s);if (fri.find(s) == fri.end()) fri[s] = "";}string find(string s) {if (fri[s] == "") return s;string root = s;while (fri[root] != "") {root = fri[root];}string pre_father;while (root != s) {pre_father = fri[s];fri[s] = root;s = pre_father;}return root;}void connect(string s1, string s2) {if (find(s1) == find(s2)) return;string root_1 = find(s1);string root_2 = find(s2);fri[root_1] = root_2;circle--;}int getCircle() {return circle;} };int main() {int N;cin >> N;string f1, f2;UF uf(N);for (int i = 0; i < N; ++i) {// john jackcin >> f1 >> f2;uf.add(f1);uf.add(f2);uf.connect(f1, f2);}cout << uf.getCircle() << endl; }總結(jié)
以上是生活随笔為你收集整理的【秋招机试真题】华为机试0407-1-幼儿园小朋友分组的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 重磅干货 | 五万字长文总结 C/C++
- 下一篇: 巨量算数data解密