結果

問題 No.2702 Nand Nor Matrix
ユーザー tails
提出日時 2024-03-31 16:05:56
言語 C90
(gcc 12.3.0)
結果
AC  
実行時間 8 ms / 2,000 ms
コード長 803 bytes
コンパイル時間 673 ms
コンパイル使用メモリ 24,832 KB
実行使用メモリ 8,064 KB
最終ジャッジ日時 2024-09-30 21:01:17
合計ジャッジ時間 7,826 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 51
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: In function ‘main’:
main.c:42:9: warning: implicit declaration of function ‘write’ [-Wimplicit-function-declaration]
   42 |         write(1,wbuf,wp-wbuf);
      |         ^~~~~
main.c:43:9: warning: implicit declaration of function ‘_exit’ [-Wimplicit-function-declaration]
   43 |         _exit(0);
      |         ^~~~~
main.c:43:9: warning: incompatible implicit declaration of built-in function ‘_exit’ [-Wbuiltin-declaration-mismatch]

ソースコード

diff #

#pragma GCC optimize("Ofast")
#pragma GCC target("avx2")

#define rd_init() char*rp=({char*mmap();mmap(0l,1l<<25,1,2,0,0ll);})
#define rd() ({int _v=0,_c;while(_c=*rp++-48,_c>=0)_v=_v*10+_c;_v;})
#define rd_long() ({long _v=0,_c;while(_c=*rp++-48,_c>=0)_v=_v*10+_c;_v;})

char wbuf[1<<25];

int main(){
	rd_init();
	int n=rd();
	char*a=rp;
	char*b=rp+(n-1)*2;
	rp+=(n*2-1)*2;
	int ae=2;
	while(ae<n&&a[ae*2-2]!=a[ae*2])++ae;
	int be=2;
	while(be<n&&b[be*2-2]!=b[be*2])++be;
	if(a[2]!=b[2])be=0;
	char*wp=wbuf;
	for(int q=rd();q--;){
		long t=rd_long();
		int r=rd()-1;
		int c=rd()-1;
		int z;
		if(r==0){
			z=a[c*2];
		}
		else if(c==0){
			z=b[r*2];
		}
		else if(r<be&&c<ae&&t>r+c-2){
			z=a[2]^r+c+1&1;
		}
		else{
			z='0'|t&1;
		}
		*wp++=z;
		*wp++='\n';
	}
	write(1,wbuf,wp-wbuf);
	_exit(0);
}
0