답안 #982762

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
982762 2024-05-14T17:28:43 Z alo_54 게임 (APIO22_game) C++17
0 / 100
0 ms 344 KB
#include "game.h"
#include <bits/stdc++.h>
using namespace std;

struct Nodo
{
  vector <int> ady;
  bool special = false;

};

vector <Nodo> g;
vector <bool> vis;

int dfs(int node, bool isSpecial)
{
  //cout<<"call "<<node<<endl;

  vis[node] = true;

  if (g[node].special)
  {
    isSpecial = true;
  }

  int resp = 0;
  

  for (auto i : g[node].ady)
  {
    //cout<<"check "<<i<<endl;
    if (!vis[i])
    {
      return dfs(i, isSpecial);
    }else
    {
      if (isSpecial)
      {
        resp = 1;
      }
    }
  }

  return resp;


}

void init(int n, int k) 
{
  vis.resize(n);
  g.resize(n);

  for (int i = 0; i < n; i++)
  {
    g[i].special = false;
  }
  
  for (int i = 0; i < k; i++)
  {
    g[i].special = true;
    
    if (i != k - 1)
    {
      g[i].ady.push_back(i + 1);
    }
    
  }
  
}

int add_teleporter(int u, int v) 
{
  fill(vis.begin(), vis.end(), false);
  g[u].ady.push_back(v);
  //cout<<"."<<g[u].ady.back()<<endl;

  int resp = 0;

  resp = dfs(u, false);
  
  return resp;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 344 KB Output is correct
2 Incorrect 0 ms 344 KB Wrong Answer[1]
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 344 KB Output is correct
2 Incorrect 0 ms 344 KB Wrong Answer[1]
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 344 KB Output is correct
2 Incorrect 0 ms 344 KB Wrong Answer[1]
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 344 KB Output is correct
2 Incorrect 0 ms 344 KB Wrong Answer[1]
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 344 KB Output is correct
2 Incorrect 0 ms 344 KB Wrong Answer[1]
3 Halted 0 ms 0 KB -