# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
30113 | khsoo01 | Untitled (POI11_smi) | C++11 | 1269 ms | 137024 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
using namespace std;
typedef pair<int,int> pii;
const int N = 100005, M = 1000005;
int n, m, cur[N];
bool vis[M], ins[N];
vector<pii> adj[N];
vector<int> st;
vector<vector<int> > ans;
void dfs (int C) {
if(ins[C]) {
vector<int> T;
T.push_back(C);
while(true) {
int X = st.back();
st.pop_back();
ins[X] = false;
T.push_back(X);
if(X == C) break;
}
ans.push_back(T);
}
while(cur[C] < adj[C].size()) {
auto T = adj[C][cur[C]++];
int A, B; tie(A, B) = T;
if(vis[B]) continue;
vis[B] = true; ins[C] = true;
st.push_back(C); dfs(A);
}
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++) {
int A, B, C, D;
scanf("%d%d%d%d",&A,&B,&C,&D);
if(C == D) continue;
adj[A].push_back({B, i});
adj[B].push_back({A, i});
}
for(int i=1;i<=n;i++) {
if(adj[i].size() % 2) {puts("NIE"); return 0;}
}
for(int i=1;i<=n;i++) dfs(i);
printf("%d\n",ans.size());
for(int i=0;i<ans.size();i++) {
printf("%d ",(int)ans[i].size()-1);
for(auto &T : ans[i]) printf("%d ",T);
puts("");
}
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |