Submission #628987

#TimeUsernameProblemLanguageResultExecution timeMemory
628987hy_1Keys (IOI21_keys)C++17
9 / 100
3056 ms29392 KiB
#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 = 300001; int dfs(int source , vector<vector<pair<int , int > > > &adj , vector<int> &r){ stack<int> st; st.push(source); vector<bool> visited(mx , false); vector<int> stock; stock.push_back(r[source]); int cnt = 0; while(!st.empty()){ int cur = st.top(); st.pop(); stock.push_back(r[cur]); visited[cur] = true; for(pair<int , int > i : adj[cur]){ if(count(stock.begin() , stock.end() , i.second) != 0 && visited[i.first] == false){ visited[i.first] = true; st.push(i.first); stock.push_back(r[i.first]); cnt++; } } } return cnt; } vector<int> find_reachable(vector<int> r, vector<int> u, vector<int> v, vector<int> c) { vector<vector<pair<int , int > > > adj(mx); for(int i =0; i<u.size(); i++){ pair<int, int> rr; rr.first = v[i]; rr.second = c[i]; adj[u[i]].push_back(rr); pair<int , int > vv; vv.first = u[i]; vv.second = c[i]; adj[v[i]].push_back(vv); } vector<int> you(r.size()); for(int i =0; i<r.size(); i++){ you[i] = dfs(i , adj , r); } vector<int> ans(r.size()); int y = *min_element(you.begin() , you.end()); for(int i = 0; i <you.size(); i++){ if(you[i] == y) ans[i] = 1; else ans[i] = 0; } return ans; } /* 4 0 1 1 2 5 0 0 1 1 3 1 2 2 3 1 0 0 1 0 2 */ // int main(){ // int n; cin >> n; // vector<int> r(n); // for(int &i : r) cin >> i; // int m; cin >> m; // vector<int> u(m); // vector<int> v(m); // for(int &i : u) cin >> i; // for(int &i : v) cin >> i; // vector<int> c(m); // for(int &i : c) cin >> i; // // for(int i=0; i <= 10; i++){ // // cout << i << endl; // // for(pair<int, int> j : adj[i]){ // // cout << i << " " << j.first << " " << j.second << endl; // // } // // cout << endl; // // } // for(int i =0; i <n; i++){ // vector<int> ans = find_reachable(r , u , v, c); // for(int i :ans){ // cout << i << " "; // } // cout << endl; // } // return 0; // }

Compilation message (stderr)

keys.cpp: In function 'std::vector<int> find_reachable(std::vector<int>, std::vector<int>, std::vector<int>, std::vector<int>)':
keys.cpp:69:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   69 |  for(int i =0; i<u.size(); i++){
      |                ~^~~~~~~~~
keys.cpp:83:17: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   83 |  for(int i =0; i<r.size(); i++){
      |                ~^~~~~~~~~
keys.cpp:88:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   88 |  for(int i  = 0; i <you.size(); i++){
      |                  ~~^~~~~~~~~~~
#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...