我正在创建一个程序,假设检查某个输入字符串只包含某种类型的字符(ASCII字符)。我有一串属于ASCII标准的字符,对于输入字符串中的每个字符,我检查(逐个字符)是否存在于ASCII字符串中。如果角色确实存在,我会将它们移动到一个新的字符串,一个输出字符串。如果它们不存在,我会通知用户并退出程序。
但是,我正在创建的输入字符串既可以从命令行创建,也可以从文本文件创建。我的文本文件似乎总是包含几个新行,它们总是以换行符(“\ n” - 字符)结束,它总是使我的程序报告错误,无论是在字符串的末尾还是在中间。< / p>
如何重新排列以下程序的代码,以便识别“\ n”字符?下面是代码的简化,没有显示我如何定义输入字符串以及如何定义带有ASCII字符的字符串。
char inputstring[];
char outputstring[];
char asciicharacters[];
* Here I read a text-file to the inputstring, and the ASCII-characters to the asciicharacters-string *
int k,i=0;
for(i=0;i<strlen(inputstring);i++)
{
for(k=0;k<strlen(asciicharacters);k++)
{
if(inputstring[i] == asciicharacters[k])
{
outputstring[i] = inputstring[i];
break;
}
else if(k == strlen(asciicharacters)-1)
{
printf("The character: %c, is not ASCII-standard",input[i]);
exit(1);
}
}
}
当我到达“\ n”字符时,如何创建另一个使程序跳过(并接受为ASCII标准)的条件?
答案 0 :(得分:2)
您可以在最终else if
之前添加此else if
。
else if( inputstring[i] == '\n' )
{
break;
}