08.15后台美团笔试第三题小思路

不是并查集就完事了么,可能一个坑点在有序输出吧
变量名不要在意哈,随便起🤣orz
#include <bits/stdc++.h>
using namespace std;

const int Max = 10000 + 10;
int n,m;
int pre[Max],People[Max];

int find(int x){
	while(x != pre[x])
		x = pre[x];
	return x;
}
void Union(int x,int y){
	x = find(x);
	y = find(y);
	if(x!=y)
		pre[y] = x;
}

int main(){
    cin >> n >> m;
	int a,b;
	for(int i = 1; i <= n; i++)
		pre[i] = i;
	while(m--){
		cin >> a >> b;
        Union(a,b);
	}
	for(int i = 1; i <= n; i++)
		People[i] = 0;
	int k;
	map<int, vector<int>> res;
	for(int i = 1; i <= n; i++){
		k = find(i);
		res[k].push_back(i);
	}
	cout << res.size() << endl;
	map<int, vector<int> >::iterator iter = res.begin();
	vector<vector<int> > t;
	while(iter != res.end()) {
        vector<int> v = iter->second;
        vector<int> temp;
        for(int i = 0; i < v.size(); i++){
            temp.push_back(v[i]);
        }
        t.push_back(temp);
        iter++;
    }
    sort(t.begin(), t.end());

	for (vector<vector<int>>::iterator it = t.begin(); it != t.end(); ++it){
		for (int i = 0; i < (*it).size(); ++i)
			cout << (*it)[i] << " ";
        cout << endl;
	}
    return 0;
}


#笔试题目##美团#
全部评论
你并查集不超时?我并查集路径压缩 超时AC 27
点赞 回复 分享
发布于 2020-08-15 18:18
楼主第三题ac么
点赞 回复 分享
发布于 2020-08-15 18:20
咱俩思路一模一样 就这个map 都是一模一样 father作为key  vector作为value  超时啊但是?
点赞 回复 分享
发布于 2020-08-15 18:20

相关推荐

11-04 14:10
东南大学 Java
_可乐多加冰_:去市公司包卖卡的
点赞 评论 收藏
分享
10-05 23:02
东北大学 Java
我说句实话啊:那时候看三个月培训班视频,随便做个项目背点八股,都能说3 40w是侮辱价
点赞 评论 收藏
分享
点赞 3 评论
分享
牛客网
牛客企业服务