# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
629734 | hy_1 | 열쇠 (IOI21_keys) | C++17 | 10 ms | 14616 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <exception>
#include <fstream>
#include <functional>
#include <iomanip>
#include <ios>
#include <iosfwd>
#include <iostream>
#include <istream>
#include <iterator>
#include <limits>
#include <list>
#include <cmath>
#include <locale>
#include <map>
#include <memory>
#include <new>
#include <numeric>
#include <ostream>
#include <queue>
#include <set>
#include <sstream>
#include <stack>
#include <stdio.h>
#include <stdexcept>
#include <streambuf>
#include <string>
#include <typeinfo>
#include <utility>
#include <valarray>
#include <vector>
#include <unordered_map>
using namespace std;
const int mx = 300005;
void find_reachable(vector<int> r, vector<int> u, vector<int> v, vector<int> c) {
//Graph implementatiom
vector<vector<pair<int , int > > > adj(mx);
for(int i=0; i <u.size(); i++){
pair<int, int> vv;
vv.first = v[i];
vv.second = c[i];
adj[u[i]].push_back(vv);
vv.first = u[i];
vv.second = c[i];
adj[v[i]].push_back(vv);
}
//BFS
vector<int> conected(r.size());
vector<vector<int> > hash(r.size());
// cout << "ss" << endl;
for(int j = 0; j<r.size(); j++){
vector<bool> visited(r.size() , false);
int source = j;
queue<int> qu;
qu.push(source);
int cnt= 0;
hash[source].push_back(r[source]);
while(!qu.empty()){
int cur = qu.front();
qu.pop();
visited[cur] = true;
cnt += 1;
// cout << 1 << " ";
for(pair<int , int > i : adj[cur]){
if(count(hash[source].begin() , hash[source].end() , i.second) != 0 && visited[i.first] == false){
hash[source].push_back(r[i.first]);
visited[i.first] = true;
qu.push(i.first);
}
}
}
conected[j] = cnt;
}
vector<int> ans(r.size() , 0);
int uu = *min_element(conected.begin() , conected.end());
for(int i=0; i<r.size(); i++){
if(conected[i] == uu) ans[i] = 1;
}
for(int i : ans)cout << i << " ";
cout << endl;
}
/*
#1
4
0 1 1 2
5
0 0 1 1 3
1 2 2 3 1
0 0 1 0 2
2 1
0 0
0 1 0
#2
3
0 0 0
1
0
1
0
#3
7
0 1 1 2 2 1 2
10
0 0 1 1 2 3 3 4 4 5
1 2 2 3 3 4 5 5 6 6
0 0 1 0 0 1 2 0 2 1
*/
컴파일 시 표준 에러 (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... |