网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
07月16日漏签0天
广信it学院吧 关注:1,002贴子:19,237
  • 看贴

  • 图片

  • 吧主推荐

  • 游戏

  • 0回复贴,共1页
<<返回广信it学院吧
>0< 加载中...

栈的应用_就近匹配

  • 取消只看楼主
  • 收藏

  • 回复
  • 我是大番薯
  • 小有美名
    5
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
开发工具与关键技术:vs2017,C++
CSDN博客 :https://blog.csdn.net/aj64994979
撰写时间:19年7月27日
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
下面来简单实现栈的应用小案例——就近匹配,上次我发的文献,已封装好链式栈liststack.h和liststack.cpp文件,你可以引进你到的项目中加以使用。
#include"liststack.h"
using namespace std;
typedef struct PERSON
{
Linknodenode;
char*name;
intindex;
}Person;
int left(char c) {
returnc == '(';
}
int right(char c) {
returnc == ')';
}
PERSON* myperson(char*p,int index)
{
PERSON*per = (PERSON*)malloc(sizeof(PERSON));
per->name= p;
per->index= index;
returnper;
}
void ShowError(char*p,int pos){
printf("%s\n",p);
for(int i = 0; i < pos; i++)
{
printf("");
}
printf("A");
}
void main()
{
LinkStack*stack = Init_LinkStack();
char*str = "j(s)jkjlkj())ghjhhj";
char*p= str;
intindex = 0;
while(*p!='\0')
{
//如果左括号,直接进栈
if(left(*p))
{
Push_LinkStack(stack,(Linknode*)myperson(p,index));
}
if(right(*p))
{
if(Size_LinkStack(stack)>0)
{
PERSON*per = (PERSON*)Top_LinkStack(stack);
if(left(*(per->name)))
{
Pop_LinkStackSe(stack);
free(per);
}
}
else
{
printf("右括号没有匹配的左括号!\n");
ShowError(str,index);
break;
}
}
index++;
p++;
}
while(Size_LinkStack(stack)>0)
{
Person*per= (Person*)Top_LinkStack(stack);
printf("左括号没有匹配右括号!\n");
ShowError(str,index);
Pop_LinkStackSe(stack);
free(per);
}
cout<< endl;
}



登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 0回复贴,共1页
<<返回广信it学院吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示