제출 #788289

#제출 시각아이디문제언어결과실행 시간메모리
788289mannshah1211슈퍼트리 잇기 (IOI20_supertrees)C++17
40 / 100
178 ms24052 KiB
#include <bits/stdc++.h>
#include "supertrees.h"
using namespace std;



void build(vector<vector<int>> b);

struct DSU {
	vector<int> link, siz;
	DSU (int n) : link(n), siz(n, 1) {
		iota(link.begin(), link.end(), 0ll);
	}
	
	int get(int x) {
		if (link[x] == x) {
			return x;
		}
		return link[x] = get(link[x]);
	}
	
	bool unite(int a, int b) {
	   a = get(a), b = get(b);
	   if (a == b) {
	   	return false;
	   }
	   
	   if (siz[a] < siz[b]) {
	   	swap(a, b);
	   }
	   link[b] = a;
	   siz[a] += siz[b];
	   return true;
	}
	
	bool same(int a, int b) {
		return (get(a) == get(b));
	}
	
};

int construct(vector<vector<int>> p) {
	vector<vector<int>> b(p.size(), vector<int>(p.size()));
	DSU ds(p.size());
	
	bool one = true, two = true;
	for (int i = 0; i < p.size(); i++) {
		for (int j = i + 1; j < p.size(); j++) {
			if (p[i][j] != 0 && p[i][j] != 2) {
				two = false;
			}
			if (p[i][j] != 0 && p[i][j] != 1) {
				one = false;
			}
		}
	}
	
	if (one) {
		for (int i = 0; i < p.size(); i++) {
		  for (int j = i + 1; j < p.size(); j++) {
			  if (p[i][j] != 0) {
				  ds.unite(i, j);
			  }
		  }
  	}
	
	 for (int i = 0; i < p.size(); i++) {
		 for (int j = i + 1; j < p.size(); j++) {
			 if (p[i][j] == 0 && ds.same(i, j)) {
				return 0;
			 } else if (p[i][j] == 1 && !ds.same(i, j)) {
				return 0;
			 }
		 }
	 }
	
	 vector<vector<int>> conncomps(p.size());
	 for (int i = 0; i < p.size(); i++) {
	  	conncomps[ds.get(i)].push_back(i);
   }
	
	 for (int i = 0; i < conncomps.size(); i++) {
		 for (int j = 0; j < (int) conncomps[i].size() - 1; j++) {
			 b[conncomps[i][j]][conncomps[i][j + 1]] = 1;
		   b[conncomps[i][j + 1]][conncomps[i][j]] = 1;
		 }
	 }
	
	 build(b);
	 return 1;
	 }
	 for (int i = 0; i < p.size(); i++) {
		 for (int j = i + 1; j < p.size(); j++) {
			 if (p[i][j] != 0) {
				 ds.unite(i, j);
			 }
		 }
	 }
	
	 for (int i = 0; i < p.size(); i++) {
		 for (int j = i + 1; j < p.size(); j++) {
		 	 if (p[i][j] == 0 && ds.same(i, j)) {
			   return 0;
			 } else if (p[i][j] == 1 && !ds.same(i, j)) {
				 return 0;
			 }
		 }
	 }
	
	 vector<vector<int>> conncomps(p.size());
	 for (int i = 0; i < p.size(); i++) {
		 conncomps[ds.get(i)].push_back(i);
	 }
	
	 for (int i = 0; i < conncomps.size(); i++) {
		if (conncomps[i].size() < 2) {
			continue;
		}
		if (conncomps[i].size() == 2) {
			return 0;
		}
		for (int j = 0; j < conncomps[i].size(); j++) {
			b[conncomps[i][j]][conncomps[i][(j + 1) % conncomps[i].size()]] = 1;
			b[conncomps[i][(j + 1) % conncomps[i].size()]][conncomps[i][j]] = 1;
		}
	}
	
	build(b);
	return 1;
}

컴파일 시 표준 에러 (stderr) 메시지

supertrees.cpp: In function 'int construct(std::vector<std::vector<int> >)':
supertrees.cpp:47:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   47 |  for (int i = 0; i < p.size(); i++) {
      |                  ~~^~~~~~~~~~
supertrees.cpp:48:25: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   48 |   for (int j = i + 1; j < p.size(); j++) {
      |                       ~~^~~~~~~~~~
supertrees.cpp:59:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   59 |   for (int i = 0; i < p.size(); i++) {
      |                   ~~^~~~~~~~~~
supertrees.cpp:60:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   60 |     for (int j = i + 1; j < p.size(); j++) {
      |                         ~~^~~~~~~~~~
supertrees.cpp:67:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   67 |   for (int i = 0; i < p.size(); i++) {
      |                   ~~^~~~~~~~~~
supertrees.cpp:68:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   68 |    for (int j = i + 1; j < p.size(); j++) {
      |                        ~~^~~~~~~~~~
supertrees.cpp:78:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   78 |   for (int i = 0; i < p.size(); i++) {
      |                   ~~^~~~~~~~~~
supertrees.cpp:82:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   82 |   for (int i = 0; i < conncomps.size(); i++) {
      |                   ~~^~~~~~~~~~~~~~~~~~
supertrees.cpp:92:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   92 |   for (int i = 0; i < p.size(); i++) {
      |                   ~~^~~~~~~~~~
supertrees.cpp:93:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   93 |    for (int j = i + 1; j < p.size(); j++) {
      |                        ~~^~~~~~~~~~
supertrees.cpp:100:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  100 |   for (int i = 0; i < p.size(); i++) {
      |                   ~~^~~~~~~~~~
supertrees.cpp:101:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  101 |    for (int j = i + 1; j < p.size(); j++) {
      |                        ~~^~~~~~~~~~
supertrees.cpp:111:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  111 |   for (int i = 0; i < p.size(); i++) {
      |                   ~~^~~~~~~~~~
supertrees.cpp:115:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::vector<int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  115 |   for (int i = 0; i < conncomps.size(); i++) {
      |                   ~~^~~~~~~~~~~~~~~~~~
supertrees.cpp:122:21: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  122 |   for (int j = 0; j < conncomps[i].size(); j++) {
      |                   ~~^~~~~~~~~~~~~~~~~~~~~
supertrees.cpp:46:19: warning: variable 'two' set but not used [-Wunused-but-set-variable]
   46 |  bool one = true, two = true;
      |                   ^~~
#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...