编写一个程序,它从标准输入读取C源代码,并验证所有的花括号都正确的成对出现。
要验证内容 “{ }”是否成对出现,需要使用到getchar()函数来逐一检验
int main()
{
char a = 0;
int count = 0;
while ((a = getchar()) != EOF)//此处EOF是Ctrl键+Z;
{
if (a == '{')
{
count++; //用计数的方法来判断两个分号是否匹配;
}
else if (a == '}'&&count == 0)
{
printf("不匹配");//因为在另外一种*}{}{}{}{}*}情况下是不匹配的,所以在任何时刻第一个 “结束分号” 出现时count==0都是不匹配的。
}
else if (a == '}')
{
count--;
}
}
if (0 == count)
{
printf("匹配");
}
else
{
printf("不匹配");
}
system("pause");
return 0;
}
总结:首先应该相处判断是否成对的检验方法,然后再用反推的方法验证,再找出弊端后,寻找反例的规律 应用到实际问题上去
2.输入一串密码,然后按Y确认,N放弃。
此中牵扯到scanf函数和getchar()函数读取数据都实在键盘的缓冲区中,当scanf内容输入完毕时会在键盘按下回车即\n,getchar会在键盘缓冲区读取\n,从而导致程序结束。
为了修复这一问题,使用while函数将键盘缓冲区最后直至\n的字符全部吸收,最后等待Y/N
int main(){
int a = 0;
char acc[20] = { 0 };
printf("请输如密码:\n");
scanf("%s", acc);
while ((a = getchar())!= '\n')//此处用while循环将scanf输入后键盘缓存区剩余的字符吸收,直至最后回车键敲入的\n字符吸收后while循环结束
{
;
}
a = getchar();
if ('Y' == a)
{
printf("1");
}
else
{
printf("0");
}
system("pause");
return 0;
}