括号匹配问题+栈c语言总结

作者&投稿:书唐 (若有异议请与网页底部的电邮联系)

...输入一个算术表达式,判断表达式中的括号是否配对出现。
\/\/最近的栈作业~#include<iostream>using namespace std;class Stack{private:int maxSize;int top;int *p;public:Stack(int size){maxSize=size;top=-1;p=new int[maxSize];}~Stack(){delete [] p;}void Clear() \/\/清空栈{top=-1;}bool Push(const int value) \/\/压入{if(top...

C语言中的栈和堆是什么?
1、计算机中的内存分为两部分:一部分是栈(stack,也称堆栈),另一部分是堆(heap)。2、 栈,可以看作是一摞卡片,最上面的卡片表示程序的当前作用域,这往往就是当前正在执行的函数。3、堆,一段完全独立于当前函数或者栈帧的内存区。如果一个函数中声明了一些变量,而且希望当这个函数完成时其中...

C语言一大堆显示没有定义怎么办,问题主要在下面的括号匹配的代码,上 ...
第六行,i前面加一个int 因为你变量不定义就使用了。

C语言栈方面,出现一些错误,栈定义有点问题,搞不太懂
把e=&s;放到SeqStack*S=(SeqStack*)malloc(sizeof(SeqStack));后面去,c与cpp的不同是c要先在函数开头全部定义好后才能操作,不能放中间定义。int correct(char exp[])\/\/检测是否匹配函数 { int i,s,*e;SeqStack*S=(SeqStack*)malloc(sizeof(SeqStack));S->Top=0;e=&s;这样编译就没问题...

C语言,关于栈的问题 给下面的程序加上注释,并给出运行结果:
x='c';y='k';push(p,x);push(p,'a');push(p,y);\/\/将'c','a','k'依次压入堆栈 x=pop(p);\/\/弹出最顶层元素'k'给x,此时堆栈中有两个元素'a','c'push(p,'t');push(p,x);\/\/将't','k'依次压入堆栈 x=pop(p);\/\/弹出最顶层元素'k'给x,此时堆栈中有三个元素't'...

C语言中"栈"和"堆"怎么理解?
堆(heap)和栈(stack)有什么区别??简单的可以理解为:heap:是由malloc之类函数分配的空间所在地。地址是由低向高增长的。stack:是自动分配变量,以及函数调用的时候所使用的一些空间。地址是由高向低减少的。一个由c\/C++编译的程序占用的内存分为以下几个部分 1、栈区(stack)— 由编译器自动分配...

求计算机C语言中“栈”的基本概念,希望各个方面都有,全一点。最好和教 ...
栈,是硬件。主要作用表现为一种数据结构,是只能在某一端插入和删除的特殊线性表。它按照后进先出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来)。 栈是允许在同一端进行插入和删除操作的特殊线性表。允许进行插入和...

C语言,栈的实现~
include<stdio.h> include<malloc.h> \/\/enum bool {false,true};typedef struct Node{ int a;int Number; \/\/在栈中的序号,栈底为0 struct Node *next;}Node,*LpNode;typedef struct SqStack{ Node *top;Node *prev;Node *base;int length;}*LpSqStack;\/\/将e的能容复制到S中...

C语言堆和栈的区别用比喻,举例子说明?
堆和栈的区别可以引用一位前辈的比喻来看出:使用栈就象我们去饭馆里吃饭,只管点菜(发出申请)、付钱、和吃(使用),吃饱了就走,不必理会切菜、洗菜等准备工作和洗碗、刷锅等扫尾工作,他的好处是快捷,但是自由度小。使用堆就象是自己动手做喜欢吃的菜肴,比较麻烦,但是比较符合自己的口味,而且...

C语言栈的问题?错误怎么改?
就这儿错了 ElemType *e;PopQu(&qu,e);你只是定义了一个指针,而没有给他分配内存,所以你在PopQu中对他赋值会出现内存错误。修改为 ElemType *e;e = (ElemType*)malloc(sizeof(ElemType));PopQu(&qu,e);并在main函数的末尾加上这一句以便释放前面分配的内存 free(e);

空该13960991018问: c++栈的问题,写个程序解决括号的匹配问题 -
宣武区甘悦回答: int Match(char *exp,int n) { int i=0; char e; SqStack *st; InitStack(st); while(i<n) { if(exp[i]=='(') push(st,exp[i]); else if(exp[i]==')') { if(GetTop(st,e)==1) { if(e!='(') return 0; else Pop(st,e); } else return 0; } i++; } if(StackEmpty(st)==1) return 1; else return 0; }

空该13960991018问: 用栈判断括号匹配(要多种情况的,完整的,c语言程序) -
宣武区甘悦回答: #include<stdio.h> #include<stdlib.h> #include<string.h> int main(int argc, char *argv[]) {int flag = 0;FILE *fp=NULL;fp = fopen(argv[1],"rb");char ch;char stack[500];memset(stack, 0, sizeof(stack));int top = -1;while((ch=fgetc(fp))!=-1){if(ch...

空该13960991018问: 急求c语言编写的利用栈检验括号匹配的程序完整代码,谢谢啦~ -
宣武区甘悦回答: 输入:串中只含有'(', ')'两个符号,判断是否括号匹配 并不需要真正的入栈、出栈,用top移动模拟即可 #include <stdio.h> int main() {char s[256], *p;int top = 0;scanf("%s", s); for(p=s; *p; p++){if(*p == '(')++top; //入else --top; //出if(top < 0)break; //无左括号与之匹配}if(!*p && !top)puts("Yes");else puts("No"); }

空该13960991018问: C语言用栈编写括号匹配 -
宣武区甘悦回答: #define STACK_SIZE 160 //栈空间大小 #define FLASE 0 #define TRUE 1typedef int BOOL; /**栈定义**/ typedef struct {int top; //栈顶指针int ele[STACK_SIZE]; }Stack;void Initializing(Stack **s) //初始化栈为空 {*s = (Stack *)malloc(sizeof(...

空该13960991018问: 判断圆括号是否配对用C语言如何实现这是数据结构中栈的应用问题判
宣武区甘悦回答: status check() { inttStack(s);//构造空栈 push(s,'#');//表示括号串开始 ch=getchar();//读取括号串中的一个字符 bool=1;//当bool为1是,则检验正确,为0是,则检验...

空该13960991018问: C语言 括号匹配 堆栈法中的疑问 -
宣武区甘悦回答: 例二、 括号匹配的检验 假设在表达式中 ([]())或[([ ][ ])] 等为正确的格式, [( ])或([( ))或 (( )]) 均为不正确的格式.例如:考虑下列括号序列: [ ( [ ] [ ] ) ] 1 2 3 4 5 6 7 8 分析可能出现的不匹配的情况:到来的右括弧非是所“期待”的; 到来的是“不速之客”; 直到结束,也没有到来所“期待”的括弧; 算法的设计思想:1)凡出现左括弧,则进栈;2)凡出现右括弧,首先检查栈是否空 若栈空,则表明该“右括弧”多余 否则和栈顶元素比较, 若相匹配,则“左括弧出栈” 否则表明不匹配3)表达式检验结束时, 若栈空,则表明表达式中匹配正确 否则表明“左括弧”有余 你先看一下

空该13960991018问: C++用栈解决括号匹配问题,要求第一行输入n表示有n个括号表达式需要判断,以下几行输入括号,在线急等!! -
宣武区甘悦回答: 思路:1. 根据第一行的数据,初始化栈,就是栈的大小确定了2. 每行getline读入到一个变量char str3. if (str == '(' ) push到栈内.4. else if (str == ')' ) pop出栈.5. else 读入空行,continue;6. 最后判断栈是否为空,不为空就表示括号最后没匹配完.

空该13960991018问: 判断圆括号是否配对用C语言如何实现 -
宣武区甘悦回答: 如果只有圆括号(没有[ ] 或 { }),不需要构造一个栈.因为用栈实现时,栈里装的都是一模一样的左括号 '(' ,因此我们只需定义一个 整型变量 来记录 栈中元素的个数 即可.具体代码如下:#include <stdio.h> int main (void) { char input = 0;int ...

空该13960991018问: 用栈判断表达式中的括号是否配对? -
宣武区甘悦回答: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46intmatched(char* s) {charstack[1024];intn = 0;while(*s){switch(*s){case'(':if(n < 1024)stack[n++] = '(';...

空该13960991018问: 括号匹配 基本算法 -
宣武区甘悦回答: 用栈的数据结构 先读入一个括号,如果为左括号,入栈,否则,出错退出 继续读入括号,如果是右括号,检查栈,如果非空,出栈(因为不把右括号入栈,所以栈里面都是左括号),如果空,出错退出 直到读完处理完最后一个括号,如果这个时候栈为空,那么成功返回true,否则返回false


本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网