关于数据结构栈的赋值

问题描述

关于数据结构栈的赋值

#include
using namespace std;

typedef int SElemType; //???????????????ù????????
#define STACK_INIT_SIZE 100 //?¨???????????±??×??ó??
#define STACKINCREMENT 10 //?¨???????????????????????ó??

typedef struct{
SElemType *base; //?¨???á????:??
SElemType *top;
int stacksize;
}SqStack;

bool InitStack(SqStack &s){ //??????????????
s.base=(SElemType *)malloc(STACK_INIT_SIZE*sizeof(SElemType));
if(s.base=NULL) return false;
s.top=s.base;
s.stacksize=STACK_INIT_SIZE;
return true;
}

bool GetTop(SqStack s,SElemType &e){

if(s.top==s.base)   return false;

e=*(s.top-1);           //top????×??????ò×???????????·?
return true;

}

bool Push(SqStack &s,SElemType e){ //????????????????????
if(s.top-s.base>=STACK_INIT_SIZE){
s.base=(SElemType *)realloc(s.base,(s.stacksize+STACKINCREMENT)*sizeof(SElemType));
if(s.base==NULL) return false;
s.top=s.base+s.stacksize; //??top????????????
s.stacksize+=STACKINCREMENT;
}
*(s.top)=e; //????top?????ù????????????????top????????????
s.top++;
return true;
}

bool Pop(SqStack &s,SElemType &e){ //????????e ????????
if(s.base==s.top) return false;
s.top--; //????top×????????ó????????????????
e=*s.top;
return true;
}

void main(){
SqStack s;
int elem=1;

InitStack(s);

*(s.top)=5;
cout<<*s.base<<endl;

// Push(s,elem);

/* for(int i=1;i<=2;i++){
Pop(s,elem);
cout<<elem<<endl;
}*/
}

用的是vc++6.0 这样我给栈顶赋值,编译的时候没问题,为什么执行的时候就会停止工作?求解

解决方案

s.base=(SElemType *)malloc(STACK_INIT_SIZE*sizeof(SElemType));
if(s.base=NULL) return false;
刚申请完内存,你又赋空值,内存泄露了,当然运行不了。

解决方案二:

指针没有分配,或者下标越界等等。程序能编译不能运行这很正常。尤其是C++这种比较原始而简陋的语言,编译器的检查更是少的可怜。你需要学会调试。

解决方案三:

数据结构(栈)
数据结构_栈

解决方案四:

if(s.base=NULL) return false; 发现问题了,是这句话,要哭了,果然还是用java出现的问题少些,这个=真是要命。

解决方案五:

你需要学会调试编译的时候没问题

时间: 2024-12-09 03:09:49

关于数据结构栈的赋值的相关文章

数据结构――栈、队列和树(Java)

数据|数据结构 数据结构――栈.队列和树 开发者可以使用数组与链表的变体来建立更为复杂的数据结构.本节探究三种这样的数据结构:栈.队列与树.当给出算法时,出于简练,直接用Java代码. 栈 栈是这样一个数据结构,其数据项的插入和删除(获取)都只能在称为栈顶的一端完成.因为最后插入的数据项就是最先要删除的数据项,开发者往往将栈称为LILO(last-in, first-out)数据结构. 数据项压入(插入)或者弹出(删除或取得)栈顶.图13示例了一个有三个String数据项的栈,每个数据项压入栈顶

PHP SPL标准库之数据结构栈(SplStack)介绍

  这篇文章主要介绍了PHP SPL标准库之数据结构栈(SplStack)介绍,栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈),需要的朋友可以参考下 栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈) SplStack就是继承双链表(SplDoublyLinkedList)实现栈. 类摘要如下: 简单使用如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18

数据结构 栈的基本操作 进制转换 为什么运行后会陷入死循环

问题描述 数据结构 栈的基本操作 进制转换 为什么运行后会陷入死循环 ```#include #include #include #define OK 1 #define ERROR -1 #define OVERFLOW -1 #define ENDFLAG 0 #define STACK_INIT_SIZE 100//初始分配量 #define STACKINCREMENT 10//增量 typedef int Status; typedef int SElemType; typedef s

PHP SPL标准库之数据结构栈(SplStack)介绍_php实例

栈(Stack)是一种特殊的线性表,因为它只能在线性表的一端进行插入或删除元素(即进栈和出栈) SplStack就是继承双链表(SplDoublyLinkedList)实现栈. 类摘要如下: 简单使用如下: //把栈想象成一个颠倒的数组 $stack = new SplStack(); /** * 可见栈和双链表的区别就是IteratorMode改变了而已,栈的IteratorMode只能为: * (1)SplDoublyLinkedList::IT_MODE_LIFO | SplDoublyL

c++-数据结构 栈的定义 栈的定义

问题描述 数据结构 栈的定义 栈的定义 定义:栈是限定仅在表头进行插入和删除操作的线性表. 栈定义用的是数组 那为什么只能在头插入和删除 实际上到底什么啊 解决方案 只能在栈顶操作只是栈的定义要求是这样的,这样就实现了"先进后出"的效果.你应该发现普通链表.栈.队列这三种结构本质是相同的,只是人为规定只能在一端或者两端操作. 你如果直接对栈底进行操作,当然是可以的,只是这种数据结构已经不能称之为"栈"了. 如果从编程角度来说的话,假设栈是一个类,那么这个类只提供了p

数据结构之间的赋值原理

问题描述 数据结构之间的赋值原理 两个属于同一结构体的变量,若在它们之间进行赋值,这其中实现的内部机理是怎么样的? 解决方案 struct { int m1; int m2; } A, B; A.m1 = 1; A.m2 = 2; B = A; 相当于: memcpy(&B, &A, sizeof(A)); 解决方案二: 这种赋值一般都是 直接 内存拷贝

帮忙写个数据结构栈的 谢谢

问题描述 帮忙写个数据结构栈的 谢谢 1.从键盘上输入表达式. 2.分析该表达式是否合法: (1)是数字,则判断该数字的合法性.若合法,则压入数据到堆栈中. (2)是规定的运算符,则根据规则进行处理.在处理过程中,将计算该表达式的值. (3)若是其它字符,则返回错误信息. 3.若上述处理过程中没有发现错误,则认为该表达式合法,并打印处理结果. 解决方案 http://wenku.baidu.com/link?url=UQoesURrEsUM4NvE5ZacHn8kAk5HgZTj5uMfmZEg

数据结构栈的出栈入栈的指针问题

问题描述 数据结构栈的出栈入栈的指针问题 入栈时,top指针是 s.top++=e 还是s.++top=e? 出栈时,top指针是 s.top--=e 还是s.--top=e? 还有就是 top指针是指向栈顶元素or栈顶元素下一位置? 解决方案 入栈操作需要先将top指针自增,然后新的top位置的值为入栈的值,先加后用,应该是s.++top=e; 出栈时先获取栈顶元素,然后将栈顶指针减一,所以是先用后减,即s.top--=e; 主要是++的位置,++top,在前先加后用:top++在后先用后加:

求解数据结构栈的输出输入问题

问题描述 求解数据结构栈的输出输入问题 为何结果是stack?pop(s,x)的用法是什么? O(∩_∩)O谢谢 解决方案 Pop(S,x)就是把栈S中的元素弹出来,放到x中.(不过不知道是用什么Pop是用什么方式实现的,像这样按值传递可以在Pop里改变x吗?) 1.Push(S,x);Push(S,'a');Push(S,y); 之后栈为:kac: 2.Pop(S,x); 之后栈为:ac:x=k: 3.Push(S,'t');Push(S,x) 之后栈为:ktac: 4.Pop(S,x) 之后