标准输入就是键盘等输入进去的代码,这个应该使用getchar()来获取字符,然后用putchar()来输出。
代码中存在的花括号成对出现的意思就是 每有一个{就必须有一个}来匹配,并且如果先出现},后边不用读取 直接输出不匹配就行了。
最后用EOF(end of file)来结束输入。
然后判断计数器count是否为0,是,则为匹配;反之,为不匹配。
下面是c语言实现的代码:#include <stdio.h>
int main()
{
int ch;
int count = 0;//定义一个计数器count
while((ch = getchar()) != EOF) //循环输入,EOF结束
{
if(ch == '{')
{
count ++;
}
//当遇到{时,计数器+1
if(ch == '}' && count == 0)
{printf("不匹配\n");
return 0;
}
//当遇到}但计数器为0了,输出不匹配,即为}在{前边
if(ch == '}' && count !=0){
count --;
}
//当遇到}且计数器不为0时,计数器-1
}if(count == 0)
{
printf("匹配!\n");
}
else
{
printf("不匹配!\n");
}//判断计数器count
return 0;
}
这里要注意当遇到}时,先看计数器是否为0,如果没有判断,}{这种情况也会被认为是匹配的。