제출 #220667

#제출 시각아이디문제언어결과실행 시간메모리
220667DodgeBallManBitaro’s Party (JOI18_bitaro)C++14
7 / 100
2080 ms9848 KiB
#include <bits/stdc++.h> #define pii pair<int, int> #define x first #define y second using namespace std; const int N = 1e5 + 10; int sq = 333; int n, m, qu, chk[N]; vector<int> g[N]; vector<pii> ans[N]; void pre() { int mx[N]; memset( mx, -1, sizeof mx ); for( int i = 1 ; i <= n ; i++ ) ans[i].emplace_back( 0, i ); for( int u = 1 ; u <= n ; u++ ) for( int v : g[u] ) { int ret = 0; pii all[N]; for( pii x : ans[u] ) mx[x.y] = max( mx[x.y], x.x + 1 ); for( pii x : ans[v] ) mx[x.y] = max( mx[x.y], x.x ); int p1 = 0, p2 = 0; while( p1 < ans[u].size() && p2 < ans[v].size() ) { if( ans[u][p1].x + 1 > ans[v][p2].x ) all[++ret] = pii( ans[u][p1].x + 1, ans[u][p1].y ), p1++; else all[++ret] = ans[v][p2++]; } while( p1 < ans[u].size() ) all[++ret] = pii( ans[u][p1].x + 1, ans[u][p1].y ), p1++; while( p2 < ans[v].size() ) all[++ret] = ans[v][p2++]; ans[v].clear(); for( int i = 1 ; i <= ret ; i++ ) if( all[i].x == mx[all[i].y] ) { ans[v].emplace_back( all[i] ); mx[all[i].y] = -1; } //printf("\n"); while( ans[v].size() > sq ) ans[v].pop_back(); } } int push( vector<int>&nope, int q ) { int dp[N]; fill( dp, dp+N, -1e9 ); for( int i : nope ) chk[i] = 1; for( int u = 1 ; u <= n ; u++ ){ if( chk[u] && dp[u] == -1e9 ) continue; dp[u] = max( dp[u], 0 ); for( int v : g[u] ) dp[v] = max( dp[v], dp[u] + 1 ); } return dp[q] == -1e9 ? -1 : dp[q]; } int main() { scanf("%d %d %d",&n,&m,&qu); for( int i = 1, s, e ; i <= m ; i++ ) { scanf("%d %d",&s,&e); g[s].emplace_back( e ); } pre(); while( qu-- ) { int q, temp; vector<int> no; scanf("%d %d",&q,&temp); if( temp == 0 ) { printf("%d\n",ans[q][0].x); continue ; } for( int i = 1, a ; i <= temp ; i++ ) { scanf("%d",&a); chk[a] = 1; no.emplace_back( a ); } if( temp > sq ) printf("%d\n",push( no, q ) ); else { int chk = 0; for( int i = 0 ; i < ans[q].size() ; i++ ) { //printf("ANS %d %d\n",ans[q][i].x,ans[q][i].y); int idx = lower_bound( no.begin(), no.end(), ans[q][i].y ) - no.begin(); if( no[idx] != ans[q][i].y ) { printf("%d\n",ans[q][i].x); chk = 1; break; } } if( !chk ) printf("-1\n"); } for( int i : no ) chk[i] = 0; } return 0; }

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

bitaro.cpp: In function 'void pre()':
bitaro.cpp:24:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         while( p1 < ans[u].size() && p2 < ans[v].size() ) {
                ~~~^~~~~~~~~~~~~~~
bitaro.cpp:24:41: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         while( p1 < ans[u].size() && p2 < ans[v].size() ) {
                                      ~~~^~~~~~~~~~~~~~~
bitaro.cpp:28:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         while( p1 < ans[u].size() ) all[++ret] = pii( ans[u][p1].x + 1, ans[u][p1].y ), p1++;
                ~~~^~~~~~~~~~~~~~~
bitaro.cpp:29:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         while( p2 < ans[v].size() ) all[++ret] = ans[v][p2++];
                ~~~^~~~~~~~~~~~~~~
bitaro.cpp:36:30: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         while( ans[v].size() > sq ) ans[v].pop_back();
                ~~~~~~~~~~~~~~^~~~
bitaro.cpp: In function 'int main()':
bitaro.cpp:73:32: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             for( int i = 0 ; i < ans[q].size() ; i++ ) {
                              ~~^~~~~~~~~~~~~~~
bitaro.cpp:54:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d %d %d",&n,&m,&qu);
     ~~~~~^~~~~~~~~~~~~~~~~~~~~~
bitaro.cpp:56:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d %d",&s,&e);
         ~~~~~^~~~~~~~~~~~~~~
bitaro.cpp:63:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d %d",&q,&temp);
         ~~~~~^~~~~~~~~~~~~~~~~~
bitaro.cpp:66:18: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
             scanf("%d",&a);
             ~~~~~^~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...