제출 #74659

#제출 시각아이디문제언어결과실행 시간메모리
74659tmwilliamlin168어르신 집배원 (BOI14_postmen)C++14
55 / 100
564 ms55776 KiB
#include <bits/stdc++.h> using namespace std; #define getchar_unlocked getchar #define putchar_unlocked putchar int in() { char c=getchar_unlocked(); while(c<'0'||c>'9') c=getchar_unlocked(); int r=0; while(c>='0'&&c<='9') { r=r*10+c-'0'; c=getchar_unlocked(); } return r; } void out(int x) { int lz=0, r=0; while(x%10==0) { ++lz; x/=10; } while(x) { r=r*10+x%10; x/=10; } while(r) { putchar_unlocked('0'+r%10); r/=10; } while(lz--) putchar_unlocked('0'); } const int mxN=5e5; int n, m, eu[mxN], ev[mxN]; vector<int> adj[mxN], a1, a2; bool a[mxN], b[mxN]; void dfs(int u) { while(adj[u].size()) { int e=adj[u].back(); adj[u].pop_back(); if(a[e]) continue; a[e]=1; dfs(eu[e]^ev[e]^u); } a1.push_back(u); } int main() { ios_base::sync_with_stdio(0); cin.tie(0); cin >> n >> m; for(int i=0; i<m; ++i) { cin >> eu[i] >> ev[i], --eu[i], --ev[i]; adj[eu[i]].push_back(i); adj[ev[i]].push_back(i); } dfs(0); for(int i=0; i<a1.size(); ++i) { if(b[a1[i]]) { while(a2.back()!=a1[i]) { cout << a2.back()+1 << " "; b[a2.back()]=0; a2.pop_back(); } cout << a1[i]+1 << "\n"; } else { a2.push_back(a1[i]); b[a1[i]]=1; } } }

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

postmen.cpp: In function 'int main()':
postmen.cpp:65:16: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i=0; i<a1.size(); ++i) {
               ~^~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...