Submission #704199

#TimeUsernameProblemLanguageResultExecution timeMemory
704199boyliguanhanSenior Postmen (BOI14_postmen)C++17
100 / 100
343 ms75060 KiB
#include<bits/stdc++.h> #pragma GCC optimize(2) //#define getchar_unlocked _getchar_nolock using namespace std; vector<pair<int, int>> adj[500100]; bitset<500100> removed; int cnt[500100]; stack<int> sol; int read(){ int res = 0, c = getchar_unlocked(); while(c < '0' || c > '9') c = getchar_unlocked(); while(isdigit(c)) res = res*10+c - 48, c = getchar_unlocked(); return res; } void reverse(){ stack<int> temp; while(sol.size()) temp.push(sol.top()), sol.pop(); sol = temp; } void print(){ stack<int> now; bitset<500100> appeared; while(sol.size()){ if(appeared[sol.top()]){ printf("%d", sol.top()); while(now.top()!=sol.top()) printf(" %d", now.top()), appeared[now.top()] = 0, now.pop(); printf("\n"); } else { appeared[sol.top()] = 1; now.push(sol.top()); } sol.pop(); } } void dfs(int n){ for(int i = cnt[n]; i < adj[n].size(); i = cnt[n]){ cnt[n] = i+1; if(!removed[adj[n][i].second]) removed[adj[n][i].second] = 1, dfs(adj[n][i].first); } sol.push(n); } int main(){ int n = read(), m = read(); for(int i = 0; i < m; i++) { int a = read(), b = read(); adj[a].push_back({b, i}); adj[b].push_back({a, i}); } dfs(1); reverse(); print(); return 0; }

Compilation message (stderr)

postmen.cpp: In function 'void dfs(int)':
postmen.cpp:40:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   40 |     for(int i = cnt[n]; i < adj[n].size(); i = cnt[n]){
      |                         ~~^~~~~~~~~~~~~~~
postmen.cpp: In function 'int main()':
postmen.cpp:48:9: warning: unused variable 'n' [-Wunused-variable]
   48 |     int n = read(), m = read();
      |         ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...