結果

問題 No.2132 1 or X Game
ユーザー tailstails
提出日時 2022-11-28 15:21:57
言語 C90
(gcc 11.4.0)
結果
AC  
実行時間 14 ms / 2,000 ms
コード長 1,263 bytes
コンパイル時間 616 ms
コンパイル使用メモリ 29,952 KB
実行使用メモリ 12,524 KB
最終ジャッジ日時 2024-10-05 13:42:39
合計ジャッジ時間 4,075 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 0 ms
6,816 KB
testcase_01 AC 13 ms
11,752 KB
testcase_02 AC 14 ms
12,524 KB
testcase_03 AC 11 ms
8,780 KB
testcase_04 AC 14 ms
10,912 KB
testcase_05 AC 14 ms
11,980 KB
testcase_06 AC 14 ms
12,184 KB
testcase_07 AC 13 ms
11,516 KB
testcase_08 AC 13 ms
10,612 KB
testcase_09 AC 6 ms
6,816 KB
testcase_10 AC 11 ms
9,152 KB
testcase_11 AC 12 ms
9,616 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: In function ‘mkwd’:
main.c:14:20: warning: multi-character character constant [-Wmultichar]
   14 |         unsigned v='0000';
      |                    ^~~~~~
main.c: In function ‘main’:
main.c:69:9: warning: implicit declaration of function ‘write’ [-Wimplicit-function-declaration]
   69 |         write(1,wbuf,wp-wbuf);
      |         ^~~~~
main.c:70:9: warning: implicit declaration of function ‘_exit’ [-Wimplicit-function-declaration]
   70 |         _exit(0);
      |         ^~~~~
main.c:70:9: warning: incompatible implicit declaration of built-in function ‘_exit’ [-Wbuiltin-declaration-mismatch]

ソースコード

diff #

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

#define rd_skip() while(*rp++>=48)
#define rd() ({long _v=0,_c;while(_c=*rp++-48,_c>=0)_v=_v*10+_c;_v;})
#define rep(v,e) for(long v=0;v<e;++v)
#define MD 998244353

typedef unsigned long ulong;
char wbuf[1<<25];

unsigned wd[10000];
void mkwd(){
	unsigned v='0000';
	long i=0;
	rep(a,10){
		rep(b,10){
			rep(c,10){
				rep(d,10){
					wd[i++]=v;
					v+=1<<24;
				}
				v+=(1<<16)-(10<<24);
			}
			v+=(1<<8)-(10<<16);
		}
		v+=(1<<0)-(10<<8);
	}
}

int main(){
	mkwd();
	char*mmap();
	char*rp=mmap(0l,1l<<25,1,2,0,0ll);
	char*wp=wbuf;
	rd_skip();
	while(*rp){
		ulong n=rd();
		ulong x=rd();
		ulong z=n+1;
		if(!(x&1)){
			z+=(n+3)/(x+3);
		}
		z>>=1;
		unsigned y=z%MD;
		if(y>=100000000){
			*wp++='0'+y/100000000;
			y%=100000000;
			*(int*)wp=wd[y/10000];
			wp+=4;
			*(int*)wp=wd[y%10000];
			wp+=4;
		}else if(y>=10000){
			unsigned q=y/10000; y%=10000;
			if(q>=1000) *wp++='0'+q/1000;
			if(q>=100)  *wp++='0'+q/100%10;
			if(q>=10)   *wp++='0'+q/10%10;
			*wp++='0'+q%10;
			*(int*)wp=wd[y];
			wp+=4;
		}else{
			if(y>=1000) *wp++='0'+y/1000;
			if(y>=100)  *wp++='0'+y/100%10;
			if(y>=10)   *wp++='0'+y/10%10;
			*wp++='0'+y%10;
		}
		*wp++='\n';
	}
	write(1,wbuf,wp-wbuf);
	_exit(0);
}
0