C语言::验证花括号成对出现
2016-07-07 14:15
357 查看
题目要求
编写一个程序,它从标准输入(终端)读取C源代码,并验证所有的花括号都正确的成对出现。注意:你不必担心注释内部、字符串常量内部和字符常量形式的花括号。
算法总结
判断左右花括号是否成对出现需要两个条件:1.左右花括号数目必须相等.
2.当右花括号出现时,左花括号数目必须大于右花括号.
具体分析,请看C语言::验证花括号成对出现
基础版
#include<stdio.h> int main(){ //定义一个整型变量用来接收控制台数据 int ch = 0; //定义一个整型变量用来计算左花括号数目 int left = 0; //定义一个整型变量用来计算右花括号数目 int right = 0; //提示信息 printf("请输入一段字符以ctrl+z结束:\n"); //从控制台读入字符并判断是否满足循环条件。 while((ch=getchar())!=EOF){ //遇到左花括号,left+1 if(ch=='{'){ left++; } //遇到右花括号 if(ch=='}'){ //左花括号数目大于右花括号数目right+1 if(left>right){ right++; }else{ //否则就是这种情况 //{{{{}}}}}{ //}}}}}{{{{{ //..... //直接退出程序 printf("不匹配!\n"); return 0; } } } //如果程序能走到这里 //就已经排除}}}}{{{{这种特殊情况 //如果左花括号数目等于右花括号数目 if(right==left){ printf("匹配!\n"); }else{ printf("不匹配!\n"); } return 0; }
优化版
#include<stdio.h> int main(){ //定义一个整型变量用来接收控制台数据 int ch = 0; //定义一个整型变量用来记录左右花括号的状态 int count = 0; //提示信息 printf("请输入一段字符以ctrl+z结束:\n"); //从控制台读入字符并判断是否满足循环条件。 while((ch=getchar())!=EOF){ //遇到左花括号,count++ if(ch=='{'){ count++; } //遇到右花括号 if(ch=='}'){ //左花括号数目大于右花括号数目right+1 if(count>0){ count--; }else{ //否则就是这种情况 //{{{{}}}}}{ //}}}}}{{{{{ //..... //直接退出程序 printf("不匹配!\n"); return 0; } } } //如果程序能走到这里 //就已经排除}}}}{{{{这种特殊情况 //如果左花括号数目等于右花括号数目 if(count==0){ printf("匹配!\n"); }else{ printf("不匹配!\n"); } return 0; }
看完C语言::验证花括号成对出现这篇文章,99%的人都能写出这样的代码.
扩展阅读
scanf()函数功能、原型、用法和实例
getchar()函数功能、原型、用法及实例
gets()函数功能、原型、用法及实例
相关文章推荐
- 如何组织构建多文件 C 语言程序(二)
- 如何写好 C main 函数
- Lua和C语言的交互详解
- 关于C语言中参数的传值问题
- 简要对比C语言中三个用于退出进程的函数
- 深入C++中API的问题详解
- 基于C语言string函数的详解
- C语言中fchdir()函数和rewinddir()函数的使用详解
- C语言内存对齐实例详解
- C语言编程中统计输入的行数以及单词个数的方法
- C语言自动生成enum值和名字映射代码
- C语言练习题:自由落体的小球简单实例
- 使用C语言判断英文字符大小写的方法
- c语言实现的带通配符匹配算法
- C语言实现顺序表基本操作汇总
- C语言中进制知识汇总
- C语言判断一个数是否是2的幂次方或4的幂次方
- C语言中计算正弦的相关函数总结
- 使用C语言详解霍夫曼树数据结构
- C语言实现选择排序、冒泡排序和快速排序的代码示例