C代码实现栈
# include <stdio.h>
# include <malloc.h>
# include <stdlib.h>
//C语言实现栈 //结点
typedef struct Node{
int data;//数据
struct Node* pNext;//指针
}* PNODE,NODE; //栈
typedef struct stack{
PNODE pTop;
PNODE pBottom;
}* PSTACK,STACK; void init(PSTACK s);
void push(PSTACK s,int num);
bool isEmpty(PSTACK s) ;
bool pop(PSTACK s) ;
void traverse(PSTACK s);
void clear(PSTACK s) ; int main(void)
{
STACK s;
init(&s);
if(isEmpty(&s)){
printf("栈为空\n");
}
//压栈
push(&s,);
push(&s,);
push(&s,);
push(&s,);
push(&s,);
push(&s,);
push(&s,);
//遍历
traverse(&s);
//出栈
if(pop(&s)){
printf("出栈成功\n");
}
else{
printf("出栈失败\n");
}
traverse(&s);
clear(&s);
if(isEmpty(&s)){
printf("栈为空\n");
}
return ;
} //初始化一个空栈
void init(PSTACK s)
{
s->pTop = (PNODE)malloc(sizeof(NODE));
//判断是否申请失败
if(NULL == s->pTop) {
printf("内存申请失败");
exit(-);
}
s->pBottom = s->pTop;
s->pBottom->pNext = NULL;
} //压栈
void push(PSTACK s,int num)
{
//申请一个临时结点
PNODE tem = (PNODE)malloc(sizeof(NODE));
tem->data = num;
tem->pNext = s->pTop;
s->pTop = tem;
} //判断栈是否为空
bool isEmpty(PSTACK s)
{
return s->pTop==s->pBottom;
} //出栈
bool pop(PSTACK s)
{
if(isEmpty(s)){
return false;
}
else{
PNODE tem = s->pTop;
s->pTop = tem->pNext;
free(tem);
tem = NULL;
return true;
}
} //遍历栈
void traverse(PSTACK s)
{
PNODE p = s->pTop;
while(p!=s->pBottom){
printf("%d ",p->data);
p = p->pNext;
}
printf("\n");
} //清空栈
void clear(PSTACK s)
{
if(isEmpty(s)){
return;
} PNODE p = s->pTop;
PNODE q = NULL;
while (p != s->pBottom){
q = p->pNext;
free(p);
p = q;
}
s->pTop = s->pBottom;
}
C代码实现栈的更多相关文章
- 014敲代码将一个栈按升序排序,对这个栈是怎样实现的,你不应该做不论什么特殊的如果(keep it up)
敲代码将一个栈按升序排序. 对这个栈是怎样实现的,你不应该做不论什么特殊的如果. 程序中能用到的栈操作有:push | pop |isEmpty 最easy想到的就是优先队列来做此题.easy实现. ...
- java代码实现栈
这几天在老家有点事,现在弄完了,继续研究一下数据结构,这次的栈并没有对多线程进行优化,如果有想优化的童鞋可以参考我上一篇文章对队列进行的优化,话不多说,上代码: package com.voole.c ...
- 对《神奇的C语言》文中例子 5 代码的分析讨论
在春节前,我曾经参与在<神奇的C语言>一文中的例子(5)的讨论,但限于评论内容的有限,现在本文再次对这个问题单独讨论.(此问题原貌,详见<神奇的C语言>,这里我将原文中的代码稍 ...
- 调试Python代码的工具
pdb: 首先来说Python里内建的调试器,pdb.它利用一个简单的命令行界面,还有很多你在用调试器时用得上的功能.帮助系统能为你指出你能运行的命令,比如单步调试代码,操纵调用栈和设置断点. 一些它 ...
- 29. 栈的push,pop序列
题目:给定2个整数序列,其中1个是栈的push顺序,判断另一个有没有可能是对应的pop顺序 解:其实这题主要是判断进栈次数和出栈次数誓不是相等.我是用栈作的,效率不高,每一个元素最多出栈1次,进栈1此 ...
- 面试题19:包含min函数的栈
CStack.h: #pragma once class CStackElement { public: CStackElement(void){} CStackElement(int data, i ...
- erlang虚拟机代码执行原理
转载:http://blog.csdn.NET/mycwq/article/details/45653897 erlang是开源的,很多人都研究过源代码.但是,从erlang代码到c代码,这是个不小 ...
- 【Java实现】栈和队列就是这么简单
一.前言 上一篇已经讲过了链表[Java实现单向链表]了,它跟数组都是线性结构的基础,本文主要讲解线性结构的应用:栈和队列 如果写错的地方希望大家能够多多体谅并指正哦,如果有更好的理解的方式也希望能够 ...
- Postgres中postmaster代码解析(上)
之前我的一些文章都是在说Postgres的一些查询相关的代码.但是对于Postgres服务端是如何启动,后台进程是如何加载,服务端在哪里以及如何监听客户端的连接都没有一个清晰的逻辑.那么今天我来说说P ...
随机推荐
- Oracle基础知识(一)、简介与安装
文章提纲 Oracle简介与发展历程 安装实例(面向普通开发者) 一.Oracle简介与发展历程 中文名称甲骨文公司,全称为甲骨文股份有限公司(甲骨文软件系统有限公司).甲骨文已超越 IBM ,成为继 ...
- WINFORM时间控件(DATATIMEPICKER)的显示格式设置
将DateTimePicker控件拖出来后打开属性,找到Format属性,选择Costum选项: 然后找到CustomFormat属性,按照你要显示的格式来输入,示例如下: 若系统时间为:2016年1 ...
- Jquery知识点梳理
Jquery $代表选择器 JS 选取元素 操作内容 操作属性 操作样式 <div id="aa" style="width:100px; height:100px ...
- AngularJS的简单使用
官网下载:AngularJS 路由视图需要:Angular-Route.js 基于zepto的轻量级的 JavaScript UI 库: App.js 用于开发跨平台的移动Web应用 <!DO ...
- kettle系列-4.kettle定制化开发工具类
要说的话这个工具类还是比较简单的,每个方法体都比较小,但用起来还是可以的,把开发中一些常用的步骤封装了下,不用去kettle源码中找相关操作的具体实现了. 算了废话不多了,直接上重点,代码如下: im ...
- 获取json数据
通过异步获取json来展示数据表格,性能提高不少.实例如下: 前台: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999 ...
- C/C++面试知识点总结
1.中缀,后缀,前缀表达式: 后缀表达式是波兰逻辑学家卢卡西维奇(Lukasiewicz)发明的一种表示表达式的方法.这种表示方式把运算符写在运算对象的后面,例如,把a+b写成ab+,所以也称为后缀式 ...
- 解决Android中No resource found that matches android:TextAppearance.Material.Widget.Button.Inverse问题
解决Android中No resource found that matches android:TextAppearance.Material.Widget.Button.Inverse问题http ...
- F#之旅5 - 小实践之下载网页(爬虫基础库)
参考文章:https://swlaschin.gitbooks.io/fsharpforfunandprofit/content/posts/fvsc-download.html 参考的文章教了我们如 ...
- mysql从身份证号中提取生日、性别
SELECT p.ID, p.IDCardNo, IF ( LENGTH(p.IDCardNo) , CAST( , ) AS DATETIME ), CAST( CONCAT( ', , ) ) A ...