栈 c实现
栈的数组实现
stack.h
#ifndef _STACK_
#define _STACK_ #define SIZE 100 typedef int data_t; typedef struct head{
data_t data[SIZE];
int top;
}stack_t; stack_t *stack_create(); int stack_is_empty(stack_t *head);
int stack_is_full(stack_t *head);
void stack_clear(stack_t *head); int stack_push(stack_t *head, data_t data);
data_t stack_pop(stack_t *head);
data_t stack_get_top(stack_t *head); void stack_show(stack_t *head);
void stack_destory(stack_t **head); #endif
stack.c
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <strings.h> #include "sqstack.h" stack_t *stack_create()
{
stack_t *head = (stack_t *)malloc(sizeof(stack_t));
if (head == NULL) {
printf("malloc failed!\n");
return NULL;
}
bzero(head, sizeof(stack_t)); head->top = -; return head;
} int stack_is_empty(stack_t *head)
{
return head->top == -;
} int stack_is_full(stack_t *head)
{
return head->top == SIZE - ;
} void stack_clear(stack_t *head)
{
head->top = -;
} int stack_push(stack_t *head, data_t data)
{
if (stack_is_full(head)) {
printf("stack is full!\n");
return -;
} head->data[head->top+] = data;
head->top++; return ;
} data_t stack_pop(stack_t *head)
{
if (stack_is_empty(head)) {
printf("stack is empty!\n");
return -;
} data_t data = head->data[head->top];
head->top--; return data;
} data_t stack_get_top(stack_t *head)
{
if (stack_is_empty(head)) {
printf("stack is empty!\n");
return -;
} return head->data[head->top];
} void stack_show(stack_t *head)
{
int i;
for (i = head->top; i >= ; i--) {
printf("%d, ", head->data[i]);
}
printf("\n");
} void stack_destory(stack_t **head)
{
free(*head);
*head = NULL;
}
main.c
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <strings.h> #include "sqstack.h" int main()
{
stack_t *head = stack_create(); int n = ;
while (n--) {
stack_push(head, n+);
}
stack_show(head); int i;
for (i = ; i < ; i++) {
printf("%d, ", stack_get_top(head));
printf("%d\n", stack_pop(head));
}
stack_show(head); stack_destory(&head); return ;
}
栈的链表实现
lstack.h
#ifndef _STACK_
#define _STACK_ typedef int data_t; typedef struct node{
data_t data;
struct node *next;
}NODE; NODE *stack_create(); int stack_is_empty(NODE *head);
int stack_is_full(NODE *head); int stack_length(NODE *head);
void stack_clear(NODE *head); int stack_push(NODE *head, data_t data);
data_t stack_pop(NODE *head);
data_t stack_get_top(NODE *head); void stack_show(NODE *head);
void stack_destory(NODE **head); #endif
lstack.c
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <strings.h> #include "lstack.h" NODE *stack_create()
{
NODE *head = (NODE *)malloc(sizeof(NODE));
if (NULL == head) {
printf("malloc failed!\n");
return NULL;
}
bzero(head, sizeof(NODE)); head->data = -;
head->next = NULL; return head;
} int stack_is_empty(NODE *head)
{
return head->next == NULL;
} int stack_is_full(NODE *head)
{
return ;
} int stack_length(NODE *head)
{
NODE *p = head->next;
int len = ; while (NULL != p) {
len++;
p = p->next;
} return len;
} void stack_clear(NODE *head)
{
NODE *p = head->next;
NODE *q = NULL; while (NULL != p) {
q = p->next;
free(p);
p = q;
} head->next = NULL;
} int stack_push(NODE *head, data_t data)
{
NODE *p = head;
NODE *q = (NODE *)malloc(sizeof(NODE));
if (NULL == q) {
printf("malloc failed!\n");
return -;
}
q->data = data;
q->next = NULL; q->next = p->next;
p->next = q; return ;
} data_t stack_pop(NODE *head)
{
if (stack_is_empty(head)) {
printf("list is empty!\n");
return -;
} data_t data = head->next->data; NODE *p = head;
NODE *q = head->next;
p->next = q->next;
free(q);
q = NULL; return data;
} data_t stack_get_top(NODE *head)
{
if (stack_is_empty(head)) {
printf("list is empty!\n");
return -;
} return head->next->data;
} void stack_show(NODE *head)
{
NODE *p = head->next; while (NULL != p) {
printf("%d, ", p->data);
p = p->next;
}
printf("\n");
} void stack_destory(NODE **head)
{
stack_clear(*head); free(*head);
*head = NULL;
}
main.c
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <strings.h> #include "lstack.h" int main()
{
NODE *head = stack_create(); if (NULL == head) {
printf("create failed!\n");
return -;
} int n = ;
while (n--) {
if (- == stack_push(head, n+)) {
printf("insert failed!\n");
break;
}
} stack_show(head); int i;
for (i = ; i < ; i++) {
printf("%d, ", stack_get_top(head));
printf("%d\n", stack_pop(head));
} stack_destory(&head); return ;
}
栈 c实现的更多相关文章
- 通往全栈工程师的捷径 —— react
腾讯Bugly特约作者: 左明 首先,我们来看看 React 在世界范围的热度趋势,下图是关键词“房价”和 “React” 在 Google Trends 上的搜索量对比,蓝色的是 React,红色的 ...
- Java 堆内存与栈内存异同(Java Heap Memory vs Stack Memory Difference)
--reference Java Heap Memory vs Stack Memory Difference 在数据结构中,堆和栈可以说是两种最基础的数据结构,而Java中的栈内存空间和堆内存空间有 ...
- duang~免费的学习视频来啦:学霸君之全栈测试
学霸君向童鞋们推荐一款 同名学霸学习 视频教程 重点是完全免费收看学习噢!!! 今天 学霸君推荐腾讯课堂的学霸君之全栈测试 复制下方链接至腾讯课堂中报名学习 https://ke.qq.com/cou ...
- [数据结构]——链表(list)、队列(queue)和栈(stack)
在前面几篇博文中曾经提到链表(list).队列(queue)和(stack),为了更加系统化,这里统一介绍着三种数据结构及相应实现. 1)链表 首先回想一下基本的数据类型,当需要存储多个相同类型的数据 ...
- BZOJ1012: [JSOI2008]最大数maxnumber [线段树 | 单调栈+二分]
1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 8748 Solved: 3835[Submi ...
- BZOJ 4453: cys就是要拿英魂![后缀数组 ST表 单调栈类似物]
4453: cys就是要拿英魂! Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 90 Solved: 46[Submit][Status][Discu ...
- BZOJ 3238: [Ahoi2013]差异 [后缀数组 单调栈]
3238: [Ahoi2013]差异 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 2326 Solved: 1054[Submit][Status ...
- .NET全栈开发工程师学习路径
PS:最近一直反复地看博客园以前发布的一条.NET全栈开发工程师的招聘启事,觉得这是我看过最有创意也最朴实的一个招聘启事,更为重要的是它更像是一个技术提纲,能够指引我们的学习和提升,现在转载过来与各位 ...
- Nodejs之MEAN栈开发(八)---- 用户认证与会话管理详解
用户认证与会话管理基本上是每个网站必备的一个功能.在Asp.net下做的比较多,大体的思路都是先根据用户提供的用户名和密码到数据库找到用户信息,然后校验,校验成功之后记住用户的姓名和相关信息,这个信息 ...
- 匹夫细说C#:不是“栈类型”的值类型,从生命周期聊存储位置
0x00 前言: 匹夫在日常和别人交流的时候,常常会发现一旦讨论涉及到“类型”,话题的热度就会立马升温,因为很多似是而非.或者片面的概念常常被人们当做是全面和正确的答案.加之最近在园子看到有人翻译的& ...
随机推荐
- spring-mvc实现模拟数据到网页展示过程代码
spring-mvc实现模拟数据到网页展示过程代码 先看看我们的3种模拟数据到网页展示的思路图: 1.当mybatis的环境配置完成.一个动态Web项目建立好.开始导入jar包. -spring的ao ...
- java高级---->Serializable的过程分析
本次讲解中我们在上次的基础上,深入的了解一下序列化的流程以及其中的原理.关于序列化的一些知识与使用,请参见我的另一篇博客:java基础---->Serializable的使用.好了,我们进行以下 ...
- zookeeper 食谱
以示例形式说明 zk 食谱. 假定有 4 个客户端,分别执行 create -s -e /lock/read xx 或 create -s -e /lock/write 获取锁. 一.获取读锁的情况: ...
- 码云git使用一(上传本地项目到码云git服务器上)
主要讲下如果将项目部署到码云git服务器上,然后使用studio导入git项目,修改本地代码后,并同步到码云git上面. 首先:我们在码云上注册账号并登陆.官网(https://git.oschina ...
- Java IO流01-总叙
Java IO包体系结构图: 1.流式部分――IO的主体部分: 2.非流式部分——主要包含一些辅助流式部分的类,如:File类.RandomAccessFile类和FileDescriptor等类: ...
- 逆袭之旅DAY24.XIA.数组练习
2018-07-20 08:40:19 1. public void stringSort(){ String[] s = new String[]{"George"," ...
- linux系统管理 基本指令
命令提示符 [root@ssgao1987 ~]# 'root' 当前登陆用户 'ssgao1987' 主机名 '~' 当前所在目录(home目录) '#' 超级用户的提示符 '$' 普通用户的命令提 ...
- 网口扫盲二:Mac与Phy组成原理的简单分析
1. general 下图是网口结构简图.网口由CPU.MAC和PHY三部分组成.DMA控制器通常属于CPU的一部分,用虚线放在这里是为了表示DMA控制器可能会参与到网口数据传输中. MAC(Medi ...
- UVA 11990 `Dynamic'' Inversion CDQ分治, 归并排序, 树状数组, 尺取法, 三偏序统计 难度: 2
题目 https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&a ...
- day18 类与类之间的关系
今日所学内容: 1.类与类之间的关系 2.self 到底是谁? 3. 特殊成员 : 1.类与类之间的关系 在我们的世界中事物和事物之前总会有一些联系 在面向对象中,类与类之间也可以产生相关的联系 1) ...