제출 #977460

#제출 시각아이디문제언어결과실행 시간메모리
977460Amaarsaa슈퍼트리 잇기 (IOI20_supertrees)C++14
40 / 100
183 ms22292 KiB
#include<bits/stdc++.h> #include "supertrees.h" using namespace std; vector < int > adj[1002]; int ataman[10002], used[1002]; int Get(int x) { if ( x == ataman[x]) return x; return ataman[x] = Get(ataman[x]); } void Unite(int x, int y) { x = Get(x); y = Get(y); if (x == y) return ; if ( x < y) swap(x, y); ataman[x]= y; } int construct(vector<vector<int>> a) { int n = a.size(), i, j; vector < vector < int > > ans(n, vector<int>(n, 0)); int s = 1; for (i = 0; i < n; i ++) ataman[i] = i; for (i = 0; i < n; i ++) { for (j = 0; j < n; j ++) { if ( a[i][j] == 2 && i != j) Unite(i, j); } } for (i = 0; i < n; i ++) used[i] = 0; for (i = 0; i < n; i ++) { for (j = 0; j < n; j ++) { if ( i == j) continue; if ( (a[i][j] == 0 || a[i][j] == 3) && Get(i) == Get(j)) s= 0; if ( a[i][j] == 2 && Get(i) != Get(j)) s = 0; } } for (i = 0; i < n; i ++) { vector < int > v; v.push_back(i); for (j = i + 1; j < n; j ++) { if ( Get(j) == Get(i) && !used[j]) v.push_back(j); } if(v.size() == 1) continue; if ( v.size() == 2){ s = 0; break; } used[i] = 1; for (j = 1; j < v.size(); j ++) { used[v[j]] = 1; ans[v[j]][v[j - 1]] = ans[v[j - 1]][v[j]] = 1; } ans[v[0]][v[v.size() -1]] = ans[v[v.size() -1]][v[0]] = 1; } for (i = 0; i < n; i ++) ataman[i]= i, used[i] = 0; for ( i = 0; i < n; i++) { for ( j = 0; j < n; j ++) { if ( a[i][j] == 1 && i != j) Unite(i, j); } } for (i = 0; i < n; i ++) { for (j = 0; j < n; j ++) { if ( i == j) continue; if ( (a[i][j] == 0 || a[i][j] == 3) && Get(i) == Get(j)) s= 0; if ( a[i][j] == 1 && Get(i) != Get(j)) s = 0; } } for (i = 0; i < n; i ++) { vector < int > v; v.push_back(i); for (j = i + 1; j < n; j ++) { if ( Get(j) == Get(i) && !used[j]) v.push_back(j); } used[i] = 1; for (j = 1; j < v.size(); j ++) { used[v[j]] = 1; ans[v[j]][v[j - 1]] = ans[v[j - 1]][v[j]] = 1; } } if ( s == 0) return 0; build(ans); return s; }

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

supertrees.cpp: In function 'int construct(std::vector<std::vector<int> >)':
supertrees.cpp:49:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   49 |   for (j = 1; j < v.size(); j ++) {
      |               ~~^~~~~~~~~~
supertrees.cpp:78:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   78 |   for (j = 1; j < v.size(); j ++) {
      |               ~~^~~~~~~~~~
#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...