結果

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

ソースコード

diff #
raw source code

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

char rbuf[1<<20];

#define wt(v) {long _z=v;do*--wp=_z%10+48;while(_z/=10);}

main(){
	long n=read(0,rbuf,sizeof rbuf);
	n-=1;
	char*p0=rbuf;
	char*p1=rbuf+n;
	long a=0,b=0,c=*p0;
	while(p0<p1){
		long v0=*p0++;
		long v1=*--p1;
		a|=v0^v1;
		b|=v0^c;
	}
	if(!a){
		if(b){
			n=n==3?-1:n-2;
		}else{
			n=-(n&1);
		}
	}
	if(n<0){
		write(1,"-1",2);
	}else if(n==0){
		write(1,"0",1);
	}else{
		char wbuf[64],*wp=wbuf+sizeof wbuf;
		wt(n);
		write(1,wp,wbuf+sizeof wbuf-wp);
	}
	_exit(0);
}
0