結果

問題 No.18 うーさー暗号
ユーザー ElkElk
提出日時 2018-05-26 02:45:56
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 722 bytes
コンパイル時間 481 ms
コンパイル使用メモリ 26,384 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-11 03:34:46
合計ジャッジ時間 1,375 ms
ジャッジサーバーID
(参考情報)
judge13 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,380 KB
testcase_01 AC 2 ms
4,380 KB
testcase_02 AC 2 ms
4,380 KB
testcase_03 AC 1 ms
4,380 KB
testcase_04 AC 1 ms
4,376 KB
testcase_05 AC 1 ms
4,376 KB
testcase_06 AC 1 ms
4,380 KB
testcase_07 AC 2 ms
4,380 KB
testcase_08 AC 1 ms
4,376 KB
testcase_09 AC 1 ms
4,380 KB
testcase_10 AC 2 ms
4,380 KB
testcase_11 AC 2 ms
4,376 KB
testcase_12 AC 2 ms
4,376 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int abc_num(char)’:
main.cpp:13:12: warning: ‘ret’ may be used uninitialized in this function [-Wmaybe-uninitialized]
     return ret;
            ^~~
main.cpp: In function ‘int main()’:
main.cpp:26:16: warning: ‘ret’ may be used uninitialized in this function [-Wmaybe-uninitialized]
         if(pos - (i%26 + 1) >= 0){
            ~~~~^~~~~~~~~~~~

ソースコード

diff #

#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