結果

問題 No.18 うーさー暗号
コンテスト
ユーザー Elk
提出日時 2018-05-26 02:45:56
言語 C++11
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=gnu++11 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 722 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 296 ms
コンパイル使用メモリ 40,320 KB
実行使用メモリ 6,272 KB
最終ジャッジ日時 2026-03-17 18:10:17
合計ジャッジ時間 998 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge2_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 13
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function 'int abc_num(char)':
main.cpp:13:12: warning: 'ret' may be used uninitialized [-Wmaybe-uninitialized]
   13 |     return ret;
      |            ^~~
main.cpp:7:12: note: 'ret' was declared here
    7 |     int i, ret;
      |            ^~~
main.cpp: In function 'int main()':
main.cpp:26:16: warning: 'ret' may be used uninitialized [-Wmaybe-uninitialized]
   26 |         if(pos - (i%26 + 1) >= 0){
      |            ~~~~^~~~~~~~~~~~
main.cpp:7:12: note: 'ret' was declared here
    7 |     int i, ret;
      |            ^~~

ソースコード

diff #
raw source code

#include <stdio.h>
#include <string.h>

char abc[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";

int abc_num(char a){
    int i, ret;
    for(i = 0; i < 26; i++){
        if(a == abc[i]){
            ret = i;
        }
    }
    return ret;
}

int main(){
    char str[1025];
    int len, i, pos, str_pos;

    scanf("%s", str);
    len = strlen(str);
    //printf("len = %d\n", len);

    for(i = 0; i < len; i++){
        pos = abc_num(str[i]);
        if(pos - (i%26 + 1) >= 0){
            str_pos = pos - (i%26 + 1);
        }else{
            str_pos = pos - (i%26 + 1) + 26;
        }
        //printf("%d\n", str_pos);
        str[i] = abc[str_pos];
    }
    //printf("len2 = %ld\n", strlen(str));
    printf("%s\n", str);

}
0