제출 #714289

#제출 시각아이디문제언어결과실행 시간메모리
714289vjudge1Art Collections (BOI22_art)C++17
0 / 100
1 ms208 KiB
#include <bits/stdc++.h> #include "art.h" using namespace std; typedef long long ll; #define OPT ios_base::sync_with_stdio(0); \ cin.tie(0); \ cout.tie(0) #define pii pair<int,int> #define pll pair<ll,ll> #define endl "\n" #define all(v) v.begin(), v.end() #define mpr make_pair #define pb push_back #define ts to_string #define fi first #define se second #define inf 0x3F3F3F3F #define bpc __builtin_popcount #define print(v) for(int i = 0; i < v.size(); i++) \ cout << v[i] << " "; \ cout<<endl; struct DSU { vector<int> e; void init(int n) { e.assign(n, -1); } int get(int x) { if (e[x] < 0) return x; return get(e[x]); } bool together(int a, int b) { if (get(a) == get(b)) return true; return false; } int s(int x) { return -e[get(x)]; } bool un(int x, int y) { x = get(x); y = get(y); if (x == y) return false; if (e[x] > e[y]) swap(x, y); e[x] += e[y]; e[y] = x; return true; } }; vector<int> adj[41]; vector<int> s(41, 0); vector<int> ans; vector<int> indeg(41, 0); int dfs1(int a) { s[a] = 1; for (int i = 0; i < adj[a].size(); i++) { if (s[adj[a][i]]) s[a] += s[adj[a][i]]; else s[a] += dfs1(adj[a][i]); } return s[a]; } void dfs(int a) { ans.pb(a); for (int i = 0; i < adj[a].size(); i++) { if (s[adj[a][i]] == s[a] - 1) { dfs(adj[a][i]); } } } void solve(int n) { vector<int> v; for (int i = 1; i <= n; i++) { v.pb(i); } for (int i = 1; i <= n; i++) { swap(v[0], v[i - 1]); int x = publish(v); for (int j = i + 1; j <= n; j++) { swap(v[0], v[j - 1]); int y = publish(v); swap(v[0], v[j - 1]); if (y < x) { adj[x].pb(y); indeg[y]++; } else { adj[y].pb(x); indeg[x]++; } } swap(v[0], v[i - 1]); } int root; for (int i = 1; i <= n; i++) { if (!indeg[i]) { root = i; } } dfs1(root); dfs(root); answer(ans); }

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

art.cpp: In function 'int dfs1(int)':
art.cpp:76:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   76 |     for (int i = 0; i < adj[a].size(); i++)
      |                     ~~^~~~~~~~~~~~~~~
art.cpp: In function 'void dfs(int)':
art.cpp:88:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   88 |     for (int i = 0; i < adj[a].size(); i++)
      |                     ~~^~~~~~~~~~~~~~~
art.cpp: In function 'void solve(int)':
art.cpp:136:8: warning: 'root' may be used uninitialized in this function [-Wmaybe-uninitialized]
  136 |     dfs(root);
      |     ~~~^~~~~~
interface.cpp: In function 'int publish(std::vector<int>)':
interface.cpp:20:17: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   20 |     if(v.size() != N) {
      |        ~~~~~~~~~^~~~
interface.cpp: In function 'void answer(std::vector<int>)':
interface.cpp:36:17: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   36 |     if(v.size() != N) {
      |        ~~~~~~~~~^~~~
#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...