对于 CS50 类中的问题,我必须检查 key 是否有效,即用户给出的输入是否为数字。我尝试了不同的代码,但每次,如果输入中至少有一位数字,它就会返回 key 是正确的。虽然只有当字符串的所有字符都是数字时它应该是正确的......
#include <cs50.h>
#include <stdio.h>
#include <string.h>
# include <ctype.h>
int main(int argc, string argv[])
{
if (argc !=2)
{
printf("Usage: %s key\n", argv[0]);
return 1;
}
else
{
for (int i = 0; i <= (strlen(argv[1])); i++)
{
if (isalpha(argv[1][i]))
{
printf("Usage: ./caesar key \n");
return 1;
}
else
{
printf("%s\n", argv[1]);
return 0;
}
}
}
}
当输入超过2个字符串时,应该返回1(即有效);
当字符串 [1] 不是数字时,它应该返回 1(这也是有效的);
当字符串 [1] 是一个数字时,它应该打印 2 个字符串(不起作用);
例如:我期望./caesar 222f 返回:Usage: ./caesar key,但实际输出是222f
最佳答案
您的代码仅检查字符串的第一个字符 - 它始终根据第一个字符是否为数字返回结果。
不是在循环内打印成功的结果,而是等待循环遍历所有字符,并且只有在找到非数字字符时才提前返回:
#include <cs50.h>
#include <stdio.h>
#include <string.h>
# include <ctype.h>
int main(int argc, string argv[])
{
if (argc !=2)
{
printf("Usage: %s key\n", argv[0]);
return 1;
}
else
{
for (int i = 0; i <= (strlen(argv[1])); i++)
{
if (isalpha(argv[1][i]))
{
printf("Usage: ./caesar key \n");
// Return early for badly formed argument
return 1;
}
}
// Now that all chars have been validated, print the argument
printf("%s\n", argv[1]);
return 0;
}
}
关于c - 检查字符串是否是c中的数字时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58533389/