题干:

 

解题报告:

https://codeforces.com/blog/entry/4556

【CodeForces - 190E】Counter Attack (补图bfs,卡常,dsu)

AC代码:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<queue>
#include<map>
#include<vector>
#include<set>
#include<unordered_map>
#include<string>
#include<cmath>
#include<cstring>
#define F first
#define S second
#define ll long long
#define pb push_back
#define pm make_pair
using namespace std;
typedef pair<int,int> PII;
const int MAX = 5e5 + 5;
unordered_map<int,bool> mp[MAX];
vector<int> vv;
vector<vector<int> > ans;
vector<int> bfs(int x) {
	vector<int> res;
	queue<int> q;
	q.push(x);
	while(q.size()) {
		int cur = q.front();q.pop();
		res.pb(cur);
//		int up = vv.size();这里不能这样写,因为size是动态的。
		for(int i = 0; i<(int)vv.size(); i++) {
			int v = vv[i];
			if(mp[cur].count(v) == 0) {
				swap(vv[i],vv.back());//用来实现set的erase操作,减少常数。 
				vv.pop_back();//用来实现set的erase操作 
				i--;
				q.push(v);
			}
		}
	}
	return res;
}
int main()
{
	int n,m;
	cin>>n>>m;
	for(int i = 1; i<=n; i++) vv.pb(i);
	for(int x,y,i = 1; i<=m; i++) {
		scanf("%d%d",&x,&y);
		mp[x][y]=1;
		mp[y][x]=1;
	}
	while(!vv.empty()) {
		int v = vv.back();vv.pop_back();
		vector<int> cnt = bfs(v);
		ans.push_back(cnt);
	}
	sort(ans.begin(),ans.end());
	printf("%d\n",ans.size());
	for(int i = 0; i<(int)ans.size(); i++) {
		printf("%d ",ans[i].size());
		for(int j = 0; j<(int)ans[i].size(); j++) {
			printf("%d ",ans[i][j]);
		}
		printf("\n");
	}

	return 0 ;
}

 

相关文章:

  • 2021-07-13
  • 2022-12-23
  • 2021-07-26
  • 2022-12-23
  • 2022-12-23
  • 2021-09-06
  • 2022-12-23
  • 2022-01-12
猜你喜欢
  • 2021-11-05
  • 2021-09-14
  • 2021-07-09
  • 2021-11-29
  • 2021-11-06
  • 2022-02-08
  • 2022-12-23
相关资源
相似解决方案