結果

問題 No.3503 Brackets Stack Query 2
コンテスト
ユーザー Nakanishi Hiro
提出日時 2026-04-18 00:38:10
言語 C(gnu17)
(gcc 15.2.0)
コンパイル:
gcc-15 -O2 -std=gnu17 -Wno-error=implicit-function-declaration -Wno-error=implicit-int -Wno-error=incompatible-pointer-types -Wno-error=int-conversion -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
AC  
実行時間 161 ms / 2,000 ms
コード長 364 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 281 ms
コンパイル使用メモリ 36,480 KB
実行使用メモリ 12,416 KB
最終ジャッジ日時 2026-04-18 00:38:44
合計ジャッジ時間 16,487 ms
ジャッジサーバーID
(参考情報)
judge1_1 / judge2_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 30
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c:2:69: warning: return type defaults to 'int' [-Wimplicit-int]
    2 | int q,x,l,z,y,t[800009],n[800009],o[800009],k[800009]={1};char c[3];main()
      |                                                                     ^~~~

ソースコード

diff #
raw source code

#include<stdio.h>
int q,x,l,z,y,t[800009],n[800009],o[800009],k[800009]={1};char c[3];main()
{scanf("%d",&q);while(q--){scanf("%d",&x);if(x-1)l--;else{scanf(" %c",c);y=t[l];if(!k[l])t[++l]=y,k[l]=0;else if(*c<')')n[++z]=y,o[z]=0,t[++l]=z,k[l]=1;else if(*c<'|')t[++l]=n[y],k[l]=y&&o[y];else n[++z]=n[y],o[z]=1,t[++l]=z,k[l]=y&&!o[y];}puts(k[l]&&!t[l]?"Yes":"No");}}
0