제출 #1302460

#제출 시각아이디문제언어결과실행 시간메모리
1302460aaaaaaaa세계 지도 (IOI25_worldmap)C++20
0 / 100
1191 ms2051564 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((int) ord.size(), vector<int>((int) ord.size(), 0));

  //cout << ord.size() << "\n";

  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];
  }

  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...