제출 #672619

#제출 시각아이디문제언어결과실행 시간메모리
672619paulo_ar동굴 (IOI13_cave)C++17
0 / 100
261 ms388 KiB
#include <bits/stdc++.h>
#include "cave.h"

using namespace std;

int s [5004];
int res [5004];
bool activos [5004];
int ans [5004];
int busqueda (bool esuno, int inde, int n){

    int izq=0,  der=n-1;
int mitad;
int rep=0;
int master;
    while(izq<=der){
        mitad=(izq+der)/2;

        if(esuno)master=0;
        else master=1;


           for(int i=0; i<mitad; i++){
                if(activos[i])
                    {
                    s[i]=res[i];
                }
                else{
                    s[i]=master;
                }
           }
             if(esuno)master=1;
        else master=0;
           for(int i=mitad; i<n; i++){
                if(res[i]){
                    s[i]=res[i];
                }
                else{
                    s[i]=master;
                }
           }
           int p = tryCombination(s);
         if(p>=inde or p==-1){
            der=mitad-1;
            rep=mitad;
         }
         else {
            izq=mitad+1;
         }
    }
    return rep;
}


void exploreCave(int N) {

   int ll;
    for(int i=0; i<N; i++){
        res[i]=false;
   }

   for(int j=1; j<=N; j++){
int master=1;
   for(int i=0; i<N; i++){
        if(activos[i]){
            s[i]=res[i];
        }
        else{
            s[i]=master;
        }
   }
  ll=tryCombination(s);
   int des;
   int a;
   if(ll>=j or ll==-1){
       des= busqueda(true,j,N);
           a=1;
   }
   else {
        des=busqueda(false,j,N);
        a=0;
   }

   activos [des]=true;
   res[des]=a;
   ans[j]=des;

   }

    answer(res, ans);


  // int tryCombination(int S[]);
//void answer(int S[], int D[]);
//void exploreCave(int N);
}
#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...