結果
問題 |
No.238 Mr. K's Another Gift
|
ユーザー |
![]() |
提出日時 | 2015-07-18 02:52:46 |
言語 | C90 (gcc 12.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,200 bytes |
コンパイル時間 | 320 ms |
コンパイル使用メモリ | 21,760 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-08 10:05:36 |
合計ジャッジ時間 | 2,120 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 38 WA * 2 |
コンパイルメッセージ
main.c: In function ‘main’: main.c:55:9: warning: ignoring return value of ‘fgets’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 55 | fgets(tmp, sizeof(tmp), stdin); | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
ソースコード
#include <string.h> #include <stdio.h> char s[200100]; char addC; int addPos; int saiki( int st, int gt, int rewrite ){ int ret; if( st >= gt ){ return 1; } for(;s[st] == '\0';st++); for(;s[gt] == '\0';gt--); if( s[st] != s[gt]){ if(rewrite != 0){ return 0; } rewrite = 1; addC = s[st]; addPos = gt+1; ret = saiki(st+1, gt, rewrite); if(ret == 0){ addC = s[gt]; addPos = st-1; ret = saiki(st, gt-1, rewrite); } }else{ ret = saiki(st+1, gt-1, rewrite); } return ret; } int searchReverse( int st, int gt ){ while(st < gt ){ for(;s[st] == '\0';st++); for(;s[gt] == '\0';gt--); if( s[st] != s[gt]){ return 0; } st+=1; gt-=1; } return st; } int main(void){ char tmp[100100]; int i, st=0, gt; int ret; fgets(tmp, sizeof(tmp), stdin); tmp[strlen(tmp)-1] = '\0'; for(i=0;tmp[i] != '\0';i++){ s[(i*2)+1] = tmp[i]; gt = (i*2)+2; } ret = searchReverse(st,gt); if(ret != 0){ addC = 'a'; addPos = ret; ret = 1; }else{ ret = saiki(st, gt, 0); } if(ret == 1){ s[addPos] = addC; for(i=0;i<gt+1;i++){ if(s[i] != '\0'){ printf("%c", s[i]); } } printf("\n"); }else{ printf("NA\n"); } return 0; }