C语言中怎么利用链表模拟栈
本篇文章给大家分享的是有关C语言中怎么利用链表模拟栈,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
创新互联专注于禄丰网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供禄丰营销型网站建设,禄丰网站制作、禄丰网页设计、禄丰网站官网定制、微信平台小程序开发服务,打造禄丰网络公司原创品牌,更为您提供禄丰网站排名全网营销落地服务。
1. 用C语言实现的版本
#include#include typedef char datatype; typedef struct node{ datatype data; struct node *next; } stack; stack* m_stack = NULL; /* 创建链表,从表头插入新元素 */ void creat(void); /* 使栈s为空 */ void MakeNull(); /* 判断栈是否为空 */ bool Empty(); //取出栈顶元素 int Top(datatype* value); //弹出栈顶元素 void Pop(); //入栈,在头部插入新元素 void Push(datatype x); /* 创建链表,从表头插入新元素 */ void creat() { char ch; printf("请输入字符序列:\n"); ch = getchar(); while (ch != '\n') { Push(ch); ch = getchar(); } } /* 使栈s为空 */ void MakeNull() { stack *p = m_stack; while (p != NULL) { m_stack = m_stack->next; free(p);/*释放空间*/ p = m_stack; } } /* 判断栈是否为空 */ bool Empty() { return (m_stack == NULL); } //取出栈顶元素 int Top(datatype* value) { if (Empty())/*s为空栈,直接跳出,提示出错信息*/ { return -1; } else { *value = m_stack->data; return 1; } } //弹出栈顶元素 void Pop() { stack *p; if (Empty()) /*s为空栈,直接跳出,提示出错信息*/ { printf("不能弹出,栈为空."); } else { p = m_stack;; m_stack = m_stack->next; free(p);/*释放栈顶空间*/ printf("弹出成功\n"); } } //入栈,在头部插入新元素 void Push( datatype x) { stack *p; p = (stack*)malloc(sizeof(stack)); p->data = x; p->next = m_stack; m_stack = p; } void main() { char m_top; /* 创建链表,从表头插入新元素 */ creat(); if (!Empty()) //判断栈是否为空 { int res = Top(&m_top); if (res == -1) { printf("栈为空,未能获取栈顶元素\n"); } else { printf("栈顶元素为: %c\n", m_top); } Pop(); } else { printf("栈为空\n"); } MakeNull(); }
运行结果如下图所示:
以上就是C语言中怎么利用链表模拟栈,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注创新互联行业资讯频道。
标题名称:C语言中怎么利用链表模拟栈
本文URL:http://myzitong.com/article/iggshs.html