Submission #306187

#TimeUsernameProblemLanguageResultExecution timeMemory
306187CaroLindaStray Cat (JOI20_stray)C++14
14 / 100
75 ms20220 KiB
#include "Anthony.h" #include <bits/stdc++.h> #define debug //printf #define pii pair<int,int> #define ff first #define ss second #define mk make_pair #define sz(x) (int)(x.size() ) #define ll long long #define all(x) x.begin(),x.end() const int MAXN = 2e5+10 ; using namespace std ; vector<pii> adj[MAXN] ; vector<int> marcas ; int seq[6] = {0,1,0,0,1,1} ; void dfs(int x, int father , int curIdx ) //curIdx eh o que eu tenho que colocar nas minhas proximas arestas { if( sz(adj[x]) != 2 ) curIdx = !seq[curIdx] ; else curIdx = (curIdx == 5) ? 0 : (curIdx+1) ; for(auto e : adj[x] ) { if(e.ff == father ) continue ; marcas[e.ss] = seq[curIdx] ; dfs(e.ff, x, curIdx ) ; } } void dfs3(int x, int father, int toFill ) { for(auto e : adj[x] ) { if(e.ff == father) continue ; marcas[e.ss] = toFill ; dfs3(e.ff, x, (toFill == 2 ) ? 0 : (toFill+1) ) ; } } vector<int> Mark(int N, int M, int A, int B, vector<int> U, vector<int> V) { for(int i = 0 ; i < M ; i++ ) { adj[ U[i] ].push_back(mk(V[i] , i ) ) ; adj[ V[i] ].push_back( mk(U[i],i) ) ; } marcas.resize(M, 0) ; if(A >= 3 ) dfs3(0,-1, 0) ; else { for(auto neigh : adj[0] ) { marcas[neigh.ss] = 0 ; dfs(neigh.ff, 0, 0 ) ; } } for(int i = 0 ; i < M ; i++ ) debug("Pintei %d %d de %d\n", U[i] , V[i] , marcas[i] ) ; return marcas ; }
#include "Catherine.h" #include <bits/stdc++.h> #define debug //printf #define sz(x) (int)(x.size()) #define all(x) x.begin(),x.end() #define ff first #define ss second #define pb push_back #define mk make_pair #define pii pair<int,int> using namespace std ; set< string > reversedOrder ; void Init(int A, int B) { string seq = "010011" ; //Creating reversedOrder for(int i = 0 ,ant = 5 ; i < 6 ; i++ , ant++ ) { if(ant == 6 ) ant = 0 ; string str ; for(int j = i; j != ant ; j = (j == 5 ) ? 0 : (j+1) ) str.push_back(seq[j] ) ; reversedOrder.insert(str) ; } } bool justGo , isFirst = true ; int wentBefore ; string str ; int Move(vector<int> y) { debug("meu vetor ta %d %d\n", y[0] , y[1] ) ; int qtdNeigh = y[0] + y[1] ; if(qtdNeigh == 0) { justGo = true ; return -1 ; } if(isFirst) { isFirst = false ; if(qtdNeigh == 1 ) { wentBefore = (y[0] == 1 ) ? 0 : 1 ; justGo = true ; return wentBefore ; } if(qtdNeigh == 2 ) { if( y[0] && y[1] ) { str.push_back('0') ; str.push_back('1') ; wentBefore = 1 ; return 1 ; } int idx = (y[0] > y[1] ) ? 0 : 1 ; str.push_back('0' + idx ) ; str.push_back('0' + idx ) ; wentBefore = idx ; return idx ; } wentBefore = (y[0] < y[1] ) ? 0 : 1 ; justGo = true ; return wentBefore ; } if(justGo) { if( qtdNeigh == 1 ) { wentBefore = (y[0] > y[1] ) ? 0 : 1 ; return wentBefore ; } wentBefore = !wentBefore ; return wentBefore ; } if(qtdNeigh > 1 ) { justGo = true ; if(!y[0] || !y[1] ) return -1 ; wentBefore = (y[0] == 1) ? 0 : 1 ; return wentBefore ; } //Ainda estou presa na corrente str.push_back( '0' + ( (y[0] == 1) ? 0 : 1 ) ) ; if(sz(str) == 5 ) { justGo = true ; if( reversedOrder.find(str) != reversedOrder.end() ) return -1 ; else { wentBefore = (y[0] == 1 ) ? 0 : 1 ; return wentBefore ; } } wentBefore = (y[0] == 1 ) ? 0 : 1 ; return wentBefore ; }

Compilation message (stderr)

Anthony.cpp: In function 'std::vector<int> Mark(int, int, int, int, std::vector<int>, std::vector<int>)':
Anthony.cpp:74:38: warning: left operand of comma operator has no effect [-Wunused-value]
   74 |  for(int i = 0 ; i < M ; i++ ) debug("Pintei %d %d de %d\n", U[i] , V[i] , marcas[i] ) ;
      |                                      ^~~~~~~~~~~~~~~~~~~~~~

Catherine.cpp: In function 'int Move(std::vector<int>)':
Catherine.cpp:43:8: warning: left operand of comma operator has no effect [-Wunused-value]
   43 |  debug("meu vetor ta %d %d\n", y[0] , y[1] ) ;
      |        ^~~~~~~~~~~~~~~~~~~~~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...