如何排除非数字键? CS50凯撒Pset2

时间:2020-05-05 22:24:03

标签: c cs50 caesar-cipher

我正在处理CS50凯撒(Caesar)问题,并且在大多数情况下,我的代码有效。我无法通过check50测试之一-我的代码无法处理非数字键,并且在等待程序退出时超时。

我尝试过使用isdigit,但似乎不起作用。

check50测试结果复制粘贴到下面:

:) caesar.c exists.
:) caesar.c compiles.
:) encrypts "a" as "b" using 1 as key
:) encrypts "barfoo" as "yxocll" using 23 as key
:) encrypts "BARFOO" as "EDUIRR" using 3 as key
:) encrypts "BaRFoo" as "FeVJss" using 4 as key
:) encrypts "barfoo" as "onesbb" using 65 as key
:) encrypts "world, say hello!" as "iadxp, emk tqxxa!" using 12 as key
:) handles lack of key
:( handles non-numeric key
    timed out while waiting for program to exit
:) handles too many arguments
#include <stdio.h>
#include <cs50.h>
#include <math.h>
#include <string.h>
#include <ctype.h>
#include <stdlib.h>

int main (int argc, string argv[])
{


    if (argc == 2 && (isdigit(argv[1] !=0))
    {


        int k = atoi (argv[1]); // convert string to int
        string s = get_string ("plaintext: "); // obtain text

        printf("ciphertext: ");
        for (int i = 0; i < strlen(s); i++) // text loop
        {
            if (s[i] >= 'a' && s[i] <= 'z')
            {
                printf("%c", 'a' + ((s[i] - 'a') + k) % 26);
            }

            else if (s[i] >= 'A' && s[i] <= 'Z')
            {
                printf("%c", 'A' + ((s[i] - 'A') + k) % 26);
            }

            else
            {
                printf("%c", s[i]);
            }


        }


        printf("\n");
        return 0;
    }



    else
    {
        printf("./caesar key\n");
    }

    return 1;
}

2 个答案:

答案 0 :(得分:0)

我想发生超时的原因是,您的程序正在等待纯文本,而法官没有给出明文,因为它使您的程序在给出非数字键后立即退出。

您可以使用strtol(),它接受​​指向字符的指针并保存第一个无效字符的位置。

然后,您可以通过检查返回的指针是否指向终止的空字符来检查输入是否为数字。

char* p;
int k = (int)strtol (argv[1], &p, 10);
if (*p != '\0') {
    puts("non-numeric key");
    return 1;
}

答案 1 :(得分:0)

只需循环遍历argv [1]的每个数字,然后检查它是否为整数。

for (int i = 0; i < strlen(argv[1]); i++)
{
    if (isdigit(argv[1][i]) == 0)
    {
        return 1;
    }
}