数据结构-链栈
2012-10-25 09:33
351 查看
#include<stdio.h>
#include<malloc.h>
#include<error.h>
/*
* 头节点为空
* */
typedef int datatype;
typedef struct _node_
{
datatype data;
struct _node_ *next;
}linknod,*linkstack;
linkstack creat_empty_linkstack()
{
linkstack l;
l=(linkstack)malloc(sizeof(linknod));
l->next=NULL;
return l;
}
int empty_linkstack(linkstack l)
{
return NULL==l->next;
}
int push_linkstack(linkstack h,datatype x)
{
linkstack q;
q=(linkstack)malloc(sizeof(linknod));
q->data=x;
q->next=h->next;
h->next=q;
return 1;
}
datatype pop_linkstack(linkstack h)
{
linkstack q;
datatype temp;
q=h;
q=h->next;
h->next=q->next;
temp=q->data;
free(q);
return temp;
}
datatype get_pop(linkstack h)
{
return h->next->data;
}
int clear_linkstack(linkstack h)
{
linkstack q;
if(empty_linkstack(h))
{
return 0;
}
else
{
q=h->next;
while(q!=NULL)
{
h->next=q->next;
q=h->next;
free(q);//释放指针所指到内存空间
}
q=NULL;
return 1;
}
}
int lenth_linkstack(linkstack h)
{
int len=0;
linkstack q;
if(empty_linkstack(h))
{
return 0;
}
else
{
q=h->next;
while(q!=NULL)
{
len++;
q=q->next;
}
return len;
}
}
int main(int argc,char *argv[])
{
linkstack l;
l=creat_empty_linkstack();
printf("清空:%d\n",clear_linkstack(l));
push_linkstack(l,200);
printf("栈顶指针:%d\n",get_pop(l));
push_linkstack(l,300);
printf("栈顶指针:%d\n",get_pop(l));
printf("lenth:%d\n",lenth_linkstack(l));
printf("清空:%d\n",clear_linkstack(l));
push_linkstack(l,200);
printf("栈顶指针:%d\n",get_pop(l));
printf("入栈数据:%d\n",l->next->data);
printf("判断栈是否为空:%d\n",empty_linkstack(l));
printf("出栈数据:%d\n",pop_linkstack(l));
printf("判断栈是否为空:%d\n",empty_linkstack(l));
return 0;
}
#include<malloc.h>
#include<error.h>
/*
* 头节点为空
* */
typedef int datatype;
typedef struct _node_
{
datatype data;
struct _node_ *next;
}linknod,*linkstack;
linkstack creat_empty_linkstack()
{
linkstack l;
l=(linkstack)malloc(sizeof(linknod));
l->next=NULL;
return l;
}
int empty_linkstack(linkstack l)
{
return NULL==l->next;
}
int push_linkstack(linkstack h,datatype x)
{
linkstack q;
q=(linkstack)malloc(sizeof(linknod));
q->data=x;
q->next=h->next;
h->next=q;
return 1;
}
datatype pop_linkstack(linkstack h)
{
linkstack q;
datatype temp;
q=h;
q=h->next;
h->next=q->next;
temp=q->data;
free(q);
return temp;
}
datatype get_pop(linkstack h)
{
return h->next->data;
}
int clear_linkstack(linkstack h)
{
linkstack q;
if(empty_linkstack(h))
{
return 0;
}
else
{
q=h->next;
while(q!=NULL)
{
h->next=q->next;
q=h->next;
free(q);//释放指针所指到内存空间
}
q=NULL;
return 1;
}
}
int lenth_linkstack(linkstack h)
{
int len=0;
linkstack q;
if(empty_linkstack(h))
{
return 0;
}
else
{
q=h->next;
while(q!=NULL)
{
len++;
q=q->next;
}
return len;
}
}
int main(int argc,char *argv[])
{
linkstack l;
l=creat_empty_linkstack();
printf("清空:%d\n",clear_linkstack(l));
push_linkstack(l,200);
printf("栈顶指针:%d\n",get_pop(l));
push_linkstack(l,300);
printf("栈顶指针:%d\n",get_pop(l));
printf("lenth:%d\n",lenth_linkstack(l));
printf("清空:%d\n",clear_linkstack(l));
push_linkstack(l,200);
printf("栈顶指针:%d\n",get_pop(l));
printf("入栈数据:%d\n",l->next->data);
printf("判断栈是否为空:%d\n",empty_linkstack(l));
printf("出栈数据:%d\n",pop_linkstack(l));
printf("判断栈是否为空:%d\n",empty_linkstack(l));
return 0;
}
相关文章推荐
- 数据结构 第6讲 链栈
- 数据结构-链栈(C语言)
- [数据结构]c语言实现链栈的入栈,出栈,清空,销毁等操作
- 小猪的数据结构辅助教程——3.2 栈与队列中的链栈
- C语言实现数据结构中的链栈
- 【C语言数据结构】链栈
- 【数据结构】之链栈的java实现
- 数据结构_链栈
- C数据结构-链栈
- java与数据结构(6)---java实现链栈
- 数据结构中栈的链式结构—链栈的基本操作
- Java数据结构-线性表之栈(顺序栈和链栈)
- 数据结构_线性表_顺序存储之1顺序栈2共享栈_链式存储之链栈_栈的应用举例
- 数据结构---链栈的基本操作
- 数据结构第三章实验2.实现链栈的各种基本运算
- 【数据结构】链栈的基本操作
- 数据结构学习(九)——链栈的操作
- 【数据结构】堆栈(顺序栈、链栈)的JAVA代码实现
- Java数据结构-线性表之栈(顺序栈和链栈)
- 数据结构C语言实现之链栈