| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 602 人关注过本帖
标题:括号匹配问题 求思路、代码注释。
只看楼主 加入收藏
tremere
Rank: 6Rank: 6
来 自:火星
等 级:侠之大者
帖 子:223
专家分:432
注 册:2013-3-11
结帖率:70.59%
收藏
已结贴  问题点数:20 回复次数:1 
括号匹配问题 求思路、代码注释。
括号匹配问题 求思路,求代码注释。
#include<stdio.h>
#include<stdlib.h>
#define STSIZE 100
typedef struct stack{
    char *data;
    int top;
}STack;

void inistack(STack &s)
{
    s.data = (char *)malloc(STSIZE * sizeof(char));
    s.top = 0;
}

int push(STack &s, char x)
{
    if (s.top < STSIZE )
    {
        s.data[s.top++] = x;
        return 1;
    }
    return 0;
}

char pop(STack &s)
{
    if (s.top)
        return s.data[--s.top];
    return '#';
}

char gettop(STack s)
{
    if(s.top)
        return s.data[s.top-1];
    return '#';
}

int is_right(STack &st, char *exp)
{
    int i=0;
    char ch;
    while (exp[i] != '\0')
    {
        switch (exp[i]){
            case '(': push(st, exp[i]); break;
            case '[': push(st, exp[i]); break;
            case '{': push(st, exp[i]); break;
            case ')': ch = pop(st); if (ch != '(') return 0; break;
            case ']': ch = pop(st); if (ch != '[') return 0; break;
            case '}': ch = pop(st); if (ch != '{') return 0; break;
        }
        i++;
    }
    if (st.top) return 0;
    return 1;
}
main()
{
    char exp[100], ch;
    int i=0;
    STack st;
    inistack(st);
    gets(exp);
    if (is_right(st, exp))
        printf("括号匹配正确!\n");
    else
        printf("括号错误!\n");
   
   
}
初学数据结构,很多东西不懂,希望得到诸位帮助,告诉 我思路和这些代码的详细注释。
搜索更多相关主题的帖子: include return 
2014-05-05 23:02
top398
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:2
帖 子:427
专家分:857
注 册:2014-5-2
收藏
得分:20 
这段代码用心看一下是不难理解的。
首先定义一个大小100的字符堆栈和栈顶指针,栈顶指针初始化为0。
然后是各个堆栈函数:初始化,进栈,出栈,取栈顶。
is_right 检验表达式的括号匹配,方法是:遇到 ( [ { 将其进栈,遇到 ) ] } 出栈上次的括号,并检查其是否与当前括号对应。如不对应则失败。表达式扫描完毕后检查栈顶指针是否为0(即有无未匹配的括号)。
主函数里输入表达式并调用 is_right 检查括号匹配情况并输出结果。


[ 本帖最后由 top398 于 2014-5-5 23:19 编辑 ]
2014-05-05 23:16
快速回复:括号匹配问题 求思路、代码注释。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.042846 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved