제출 #498787

#제출 시각아이디문제언어결과실행 시간메모리
498787aihayEaster Eggs (info1cup17_eastereggs)C++14
0 / 100
2 ms584 KiB
#include <bits/stdc++.h> #include "grader.h" using namespace std; #define pb push_back #define f first #define s second int vis[513],pos[513],ch[513]; int dfs(int n,vector<int>v[513],int idx=1){ vis[idx]=1; int x=1; for(int i=0;i<v[idx].size();i++){ if(!vis[v[idx][i]]) x+=dfs(n,v,v[idx][i]); } ch[idx]=x; return x; } vector<int> dfs2(int n,vector<int>v[513],int idx=1){ vis[idx]=1; vector<int> ans; ans.pb(idx); for(int i=0;i<v[idx].size();i++){ if(!vis[v[idx][i]]){ vector<int> z=dfs2(n,v,v[idx][i]); for(int j=0;j<z.size();j++){ ans.pb(z[j]); } } } return ans; } int findEgg (int n, vector<pair<int,int> > edg){ memset(vis,0,sizeof vis); memset(pos,0,sizeof pos); vector<int> v[513]; for(int i=0;i<edg.size();i++){ v[edg[i].f].pb(edg[i].s); v[edg[i].s].pb(edg[i].f); pos[edg[i].f]=1; pos[edg[i].s]=1; } dfs(n,v,1); int x=1; bool bol=1; vector<int> cur; while(1){ if(x<1||x>n) return n/2; int tk[513]={0}; vector<int> h; for(int i=1;i<=n;i++){ if(pos[i]) h.pb(i); } cout<<h.size()<<"\n"; for(int i=0;i<h.size();i++){ cout<<h[i]<<" "; } cout<<"cur: "<<cur.size()<<"\n"; for(int i=0;i<cur.size();i++){ cout<<cur[i]<<" "; } cout<<"\n"; cout<<"bol: "<<bol<<"\n"; if(cur.size()>=h.size()){ if(query(cur)){ cout<<"cur > h\n"; x=cur[0]; for(int i=0;i<cur.size();i++){ pos[cur[i]]=1; } for(int i=0;i<h.size();i++){ pos[h[i]]=0; } for(int i=0;i<v[cur[cur.size()-1]].size();i++){ if(v[cur[cur.size()-1]][i]==h[0]){ ch[cur[cur.size()-1]]-=ch[h[0]]; v[cur[cur.size()-1]][i]=v[cur[cur.size()-1]][v[cur[cur.size()-1]].size()-1]; cout<<"deleted: "<<v[cur[cur.size()-1]][v[cur[cur.size()-1]].size()-1]<<"\n"; v[cur[cur.size()-1]].pop_back(); cout<<"deleted: "<<v[cur[cur.size()-1]][v[cur[cur.size()-1]].size()-1]<<"\n"; } } } cur.clear(); continue; } cout<<"\n\n"; if(h.size()==1){ if(bol==0&&query(h)==0) for(int i=1;i<=n;i++){ for(int j=0;j<v[i].size();j++){ if(v[i][j]==x){ return i; } } } break; } int a=ch[x],b=1; vector<int> va,vb; vb.pb(x); int zz=0; for(int i=0;i<v[x].size();i++){ if(b+ch[v[x][i]]<a&&pos[v[x][i]]==1){ zz++; memset(vis,0,sizeof vis); vis[x]=1; vector<int> z=dfs2(n,v,v[x][i]); for(int j=0;j<z.size();j++){ vb.pb(z[j]); tk[z[j]]=1; } b+=ch[v[x][i]]; a-=ch[v[x][i]]; } } if(zz==0){ cout<<"element "<<x<<" added to cur\n"; cur.pb(x); pos[x]=0; if(pos[v[x][0]]) x=v[x][0]; else x=v[x][1]; continue; } for(int i=1;i<=n;i++){ if(pos[i]==1&&!tk[i]){ va.pb(i); } } cout<<"va: "<<va.size()<<"\n"; for(int i=0;i<va.size();i++) cout<<va[i]<<" "; cout<<"\n"; cout<<"vb: "<<vb.size()<<"\n"; for(int i=0;i<vb.size();i++) cout<<vb[i]<<" "; cout<<"\n\n"; if(query(vb)){ bol=0; memset(pos,0,sizeof pos); for(int i=0;i<vb.size();i++){ pos[vb[i]]=1; } cout<<"zz: "<<zz<<"\n"; if(zz==1){ for(int i=0;i<v[x].size();i++){ if(pos[v[x][i]]){ pos[x]=0; x=v[x][i]; break; } } } } else if((bol==0&&query(va))||bol==1){ bol=1; memset(pos,0,sizeof pos); for(int i=0;i<va.size();i++){ pos[va[i]]=1; } cout<<"zz: "<<zz<<"\n"; if(x!=1) zz++; if(zz==v[x].size()-1){ for(int i=0;i<v[x].size();i++){ if(pos[v[x][i]]){ pos[x]=0; x=v[x][i]; break; } } } } else{ if(cur.size()){ for(int i=0;i<cur.size();i++){ h.pb(cur[i]); pos[cur[i]]=1; } continue; } for(int i=1;i<=n;i++){ for(int j=0;j<v[i].size();j++){ if(v[i][j]==x){ return i; } } } } } return x; }

컴파일 시 표준 에러 (stderr) 메시지

eastereggs.cpp: In function 'int dfs(int, std::vector<int>*, int)':
eastereggs.cpp:13:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   13 |     for(int i=0;i<v[idx].size();i++){
      |                 ~^~~~~~~~~~~~~~
eastereggs.cpp: In function 'std::vector<int> dfs2(int, std::vector<int>*, int)':
eastereggs.cpp:24:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   24 |     for(int i=0;i<v[idx].size();i++){
      |                 ~^~~~~~~~~~~~~~
eastereggs.cpp:27:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   27 |             for(int j=0;j<z.size();j++){
      |                         ~^~~~~~~~~
eastereggs.cpp: In function 'int findEgg(int, std::vector<std::pair<int, int> >)':
eastereggs.cpp:38:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   38 |     for(int i=0;i<edg.size();i++){
      |                 ~^~~~~~~~~~~
eastereggs.cpp:58:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   58 |         for(int i=0;i<h.size();i++){
      |                     ~^~~~~~~~~
eastereggs.cpp:62:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   62 |         for(int i=0;i<cur.size();i++){
      |                     ~^~~~~~~~~~~
eastereggs.cpp:71:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   71 |                 for(int i=0;i<cur.size();i++){
      |                             ~^~~~~~~~~~~
eastereggs.cpp:74:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   74 |                 for(int i=0;i<h.size();i++){
      |                             ~^~~~~~~~~
eastereggs.cpp:77:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   77 |                 for(int i=0;i<v[cur[cur.size()-1]].size();i++){
      |                             ~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
eastereggs.cpp:94:34: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   94 |                     for(int j=0;j<v[i].size();j++){
      |                                 ~^~~~~~~~~~~~
eastereggs.cpp:106:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  106 |         for(int i=0;i<v[x].size();i++){
      |                     ~^~~~~~~~~~~~
eastereggs.cpp:112:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  112 |                 for(int j=0;j<z.size();j++){
      |                             ~^~~~~~~~~
eastereggs.cpp:136:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  136 |         for(int i=0;i<va.size();i++)
      |                     ~^~~~~~~~~~
eastereggs.cpp:140:22: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  140 |         for(int i=0;i<vb.size();i++)
      |                     ~^~~~~~~~~~
eastereggs.cpp:146:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  146 |             for(int i=0;i<vb.size();i++){
      |                         ~^~~~~~~~~~
eastereggs.cpp:151:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  151 |                 for(int i=0;i<v[x].size();i++){
      |                             ~^~~~~~~~~~~~
eastereggs.cpp:163:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  163 |             for(int i=0;i<va.size();i++){
      |                         ~^~~~~~~~~~
eastereggs.cpp:169:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  169 |             if(zz==v[x].size()-1){
      |                ~~^~~~~~~~~~~~~~~
eastereggs.cpp:170:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  170 |                 for(int i=0;i<v[x].size();i++){
      |                             ~^~~~~~~~~~~~
eastereggs.cpp:181:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  181 |                 for(int i=0;i<cur.size();i++){
      |                             ~^~~~~~~~~~~
eastereggs.cpp:188:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  188 |                 for(int j=0;j<v[i].size();j++){
      |                             ~^~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...