제출 #1302494

#제출 시각아이디문제언어결과실행 시간메모리
1302494aaaaaaaa세계 지도 (IOI25_worldmap)C++20
15 / 100
1227 ms2033564 KiB
#include "worldmap.h"
#include <bits/stdc++.h>
using namespace std;

const int mxN = 42;

vector<pair<int, int>> ord;
vector<int> adj[mxN];

void dfs(int u, int par){
    if(par > 0) ord.push_back({u, par});
    for(auto it : adj[u]){
        if(it ^ par) dfs(it, u);
    }
    if(par > 0) ord.push_back({par, u});
}

vector<vector<int>> create_map(int N, int M, vector<int> A, vector<int> B) {

  for(int i = 0; i < M; ++i){
    adj[A[i]].push_back(B[i]);
    adj[B[i]].push_back(A[i]);
  }

  dfs(1, 0);


  vector<vector<int>> ans(max(1, (int) ord.size()), vector<int>(max(1, (int) ord.size()), 1));


  for(int i = 0; i < ord.size(); ++i){
    ans[i][0] = ord[i].first;
    ans[i][1] = ord[i].second;
    for(int j = 2; j < ord.size(); ++j) ans[i][j] = ans[i][j - 1];
  }

  assert(ans.size() <=  2 * N + 2);

  for(int i = 1; i <= N; ++i) adj[i].clear();
  ord.clear();

  return ans;
}
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...