結果

問題 No.1287 えぬけー
コンテスト
ユーザー 👑 tails
提出日時 2020-11-16 17:20:15
言語 C90(gcc12)
(gcc 12.4.0)
コンパイル:
gcc-12 -O2 -std=c90 -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
AC  
実行時間 32 ms / 2,000 ms
コード長 955 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 205 ms
コンパイル使用メモリ 33,580 KB
実行使用メモリ 7,844 KB
最終ジャッジ日時 2026-03-08 16:23:35
合計ジャッジ時間 1,302 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 5
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

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

char*mmap();
#define RD(v) long v=0;{int _c;while(_c=*rp++-48,_c>=0)v=v*10+_c;}

char wbuf[11*100000];

#define MD 1000000007

main(){
	char*rp=mmap(0l,21l*100000+100,1,2,0,0ll);
	char*wp=wbuf;
	while(*rp++!=10);
	do{
		RD(x);
		RD(k);
		
		long s=MD-1;
		long u=1;
		long v=0;
		while(s){
			long e=k/s;
			{ long t=k-e*s; k=s; s=t; }
			{ long t=u-e*v; u=v; v=t; }
		}
		u+=u<0?MD-1:0;
		
		long z=1;
		for(;u;u>>=1){
			if(u&1){
				z=z*x%MD;
			}
			x=x*x%MD;
		}
		
		if(z>=100000000){
			{
				long z2=z/100000000;
				long n=0;
				long d=0;
				while(d=d<<8|z2%10|0x30,++n,z2/=10);
				*(long*)wp=d;
				wp+=n;
			}
			{
				long n=8;
				long d=0;
				while(d=d<<8|z%10|0x30,z/=10,--n);
				*(long*)wp=d;
				wp+=8;
			}
		}else{
			long n=0;
			long d=0;
			while(d=d<<8|0x30|z%10,++n,z/=10);
			*(long*)wp=d;
			wp+=n;
		}
		*wp++=10;
	}while(*rp);
	write(1,wbuf,wp-wbuf);
	_exit(0);
}
0