15. 检查括号是否匹配

【问题描述】

编写一个程序,用于对C源程序进行括号匹配检查,并将检查结果输出到文件中。
程序应检查输入源程序中左右大括号、小括号的个数是否相等,并且符合C语言语法规定的括号嵌套规则,不得交叉嵌套。输入文件最长不超过500个字符。
本程序只检查括号是否匹配,不用对输入源程序中的其它语法成份进行检查。
【输入文件】

输入文件为当前目录下的check.in,是一段任意的C程序。
【输出文件】

输出文件为当前目录下的check.out。该文件只有一行,是一个单词"True"或"False"。如果没有括号匹配错误则输出"True",否则输出"False"。
【样例输入】

输入文件check.in的内容如下:

static void PrintArr (int *p)
{
    int i = 0;
    while (*(p+i))
        printf ("%4d", *(p + i));
       i++;
    }
    printf ("\r\n");
    return;
}

【样例输出】

输出文件check.out内容如下:

False
【样例说明】

在输入的源程序中,while语句缺少一个左大括号,输出为False。

f = open('check.in')
str_f = f.read()
count_1 = 0  # {
count_2 = 0  # }
count_3 = 0  # (
count_4 = 0  # )
count_5 = 0  # [
count_6 = 0  # ]
for i in str_f:
    if i == '{':
        count_1 += 1
    elif i == '}':
        count_2 += 1
    elif i == '(':
        count_3 += 1
    elif i == ')':
        count_4 += 1
    elif i == '[':
        count_5 += 1
    elif i == ']':
        count_6 += 1
    else:
        continue
g = open('check.out', 'a')
g.seek(0)  # 定位
g.truncate()  # 从定位位置以后清空
if (count_1 == count_2) and (count_3 == count_4) and (count_5 == count_6):
    g.write('True')
else:
    g.write('False')
f.close()
g.close()
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值