Submission #1287019

#TimeUsernameProblemLanguageResultExecution timeMemory
1287019nathlol2Connecting Supertrees (IOI20_supertrees)C++20
11 / 100
98 ms30212 KiB
#include "supertrees.h"
#include <bits/stdc++.h>
using namespace std;
int N, idx;
vector<bool> vis(1005, false);
vector<vector<int>> c;
vector<vector<int>> chk;
void dfs(int u){
	vis[u] = 1;
	chk[idx].push_back(u);
	for(int i = 0;i<N;i++){
		if(!vis[i] && c[u][i]){
			dfs(i);
		}
	}
}
int construct(std::vector<std::vector<int>> p) {
	N = p.size();
	vector<vector<int>> ans(N, vector<int>(N, 0));
	vector<vector<int>> g(N);
	vector<bool> v(N, 0);
	for(int i = 0;i<N;i++){
		for(int j = 0;j<N;j++){
			if(i == j) continue;
			if(p[i][j]){
				g[i].push_back(j);
			}
		}
	}
	for(int i = 0;i<N;i++){
		if(v[i]) continue;
		v[i] = 1;
		int pv = i;
		for(auto x : g[i]){
			v[x] = 1;
			ans[pv][x] = 1;
			ans[x][pv] = 1;
			pv = x;
		}
	}
	c = ans;
	for(int i = 0;i<N;i++) if(!vis[i]) chk.push_back({}), dfs(i), idx++;
	for(auto x : chk){
		for(int i = 0;i<x.size();i++){
			for(int j = i + 1;j<x.size();j++){
				if(p[i][j] == 0) return 0;
			}
		}
	}
	build(ans);
	return 1;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...