Submission #914207

#TimeUsernameProblemLanguageResultExecution timeMemory
914207YassirSalamaICC (CEOI16_icc)C++17
90 / 100
106 ms668 KiB
#include <iostream> #include <vector> #include <algorithm> #include <unordered_map> #include <set> #include <unordered_set> #include <iomanip> #include <cmath> #include <limits> #include <map> #include <utility> #include <cctype> #include <string> #include <cstring> #include <stack> #include <queue> #include<assert.h> #include <functional> #include <iterator> #include "icc.h" using namespace std; #define OVL(x,s) for(auto y:x) cout<<y<<s; cout<<"\n"; #ifdef IOI void dbg_out() { cout << endl; } template<typename Head, typename... Tail> void dbg_out(Head H, Tail... T) { cout << ' ' << H; dbg_out(T...); } #define dbg(...) cout << "(" << #__VA_ARGS__ << "):", dbg_out(__VA_ARGS__); #else #define dbg(...) 1337; #endif #define endl "\n" #define pb push_back #define F first #define S second #define ll long long #define mod 1000000007 #define all(v) v.begin(),v.end() int ask(vector<int> a,vector<int> b){ int n=a.size(); int m=b.size(); int A[n]; int B[m]; for(int i=0;i<n;i++) A[i]=a[i]; for(int i=0;i<m;i++) B[i]=b[i]; return query(n,m,A,B); } const int MAXN=2e2+100; int par[MAXN]; vector<vector<int>> v(MAXN); struct DSU { DSU(){ for(int i=0;i<MAXN;i++) { par[i]=i; v[i].pb(i); } } int find(int node){ return node==par[node]?node:par[node]=find(par[node]); } bool same(int a,int b){ return find(a)==find(b); } void merge(int a,int b){ a=find(a); b=find(b); if(a==b) return; if(v[a].size()<v[b].size()) swap(a,b); for(auto x:v[b]) v[a].pb(x); v[b].clear(); par[b]=a; } }; int n; DSU dsu=DSU(); pair<int,int> dnc(vector<int> a,vector<int> b,int n,int m){ if(n==1&&m==1) { return {a[0],b[0]}; } vector<int> c,d; int mid=n/2; for(int i=0;i<mid;i++){ c.pb(a[i]); } for(int i=mid;i<n;i++) d.pb(a[i]); if(c.size()&&ask(b,c)){ int mid=m/2; vector<int> x,y; for(int i=0;i<mid;i++) x.pb(b[i]); for(int i=mid;i<m;i++) y.pb(b[i]); if(x.size()&&ask(c,x)) return dnc(x,c,x.size(),c.size()); else return dnc(y,c,y.size(),c.size()); } else{ int mid=m/2; vector<int> x,y; for(int i=0;i<mid;i++) x.pb(b[i]); for(int i=mid;i<m;i++) y.pb(b[i]); if(x.size()&&ask(d,x)) return dnc(x,d,x.size(),d.size()); else return dnc(y,d,y.size(),d.size()); } return {0,0}; } void solve(){ set<int> d; for(int i=1;i<=n;i++) d.insert(dsu.find(i)); vector<pair<vector<int>,vector<int>>> sets; for(int bit=0;bit<=log2(n);bit++){ vector<int> a,b; for(auto x:d){ if(x&(1<<bit)) { for(auto y:v[x]){ a.push_back(y); continue; } } else { for(auto y:v[x]){ b.push_back(y); } } } sets.push_back({a,b}); } for(auto x:sets){ vector<int> a=x.F,b=x.S; if(ask(a,b)){ //there is a road between those 2 sets pair<int,int> c=dnc(a,b,a.size(),b.size()); int x=c.F; int y=c.S; // dbg(x,y) setRoad(x,y); dsu.merge(x,y); return; } } } void run(int N){ n=N; for(int wwww=0;wwww<n-1;wwww++){ solve(); } } #ifdef IOI int main(){ int n; cin>>n; vector<pair<int,int>> v; for(int i=0;i<n-1;i++){ int a,b; cin>>a>>b; v.pb({a,b}); } for(int i=0;i<MMS;i++) pr[i]=i; EDGES=v; mp[{EDGES[0].F,EDGES[0].S}]=1; mp[{EDGES[0].S,EDGES[0].F}]=1; merge(EDGES[0].F,EDGES[0].S); run(n); cout<<"YES"<<endl; } #endif
#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...