栈的数组实现

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实现的更多相关文章

  1. 通往全栈工程师的捷径 —— react

    腾讯Bugly特约作者: 左明 首先,我们来看看 React 在世界范围的热度趋势,下图是关键词“房价”和 “React” 在 Google Trends 上的搜索量对比,蓝色的是 React,红色的 ...

  2. Java 堆内存与栈内存异同(Java Heap Memory vs Stack Memory Difference)

    --reference Java Heap Memory vs Stack Memory Difference 在数据结构中,堆和栈可以说是两种最基础的数据结构,而Java中的栈内存空间和堆内存空间有 ...

  3. duang~免费的学习视频来啦:学霸君之全栈测试

    学霸君向童鞋们推荐一款 同名学霸学习 视频教程 重点是完全免费收看学习噢!!! 今天 学霸君推荐腾讯课堂的学霸君之全栈测试 复制下方链接至腾讯课堂中报名学习 https://ke.qq.com/cou ...

  4. [数据结构]——链表(list)、队列(queue)和栈(stack)

    在前面几篇博文中曾经提到链表(list).队列(queue)和(stack),为了更加系统化,这里统一介绍着三种数据结构及相应实现. 1)链表 首先回想一下基本的数据类型,当需要存储多个相同类型的数据 ...

  5. BZOJ1012: [JSOI2008]最大数maxnumber [线段树 | 单调栈+二分]

    1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 8748  Solved: 3835[Submi ...

  6. BZOJ 4453: cys就是要拿英魂![后缀数组 ST表 单调栈类似物]

    4453: cys就是要拿英魂! Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 90  Solved: 46[Submit][Status][Discu ...

  7. BZOJ 3238: [Ahoi2013]差异 [后缀数组 单调栈]

    3238: [Ahoi2013]差异 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2326  Solved: 1054[Submit][Status ...

  8. .NET全栈开发工程师学习路径

    PS:最近一直反复地看博客园以前发布的一条.NET全栈开发工程师的招聘启事,觉得这是我看过最有创意也最朴实的一个招聘启事,更为重要的是它更像是一个技术提纲,能够指引我们的学习和提升,现在转载过来与各位 ...

  9. Nodejs之MEAN栈开发(八)---- 用户认证与会话管理详解

    用户认证与会话管理基本上是每个网站必备的一个功能.在Asp.net下做的比较多,大体的思路都是先根据用户提供的用户名和密码到数据库找到用户信息,然后校验,校验成功之后记住用户的姓名和相关信息,这个信息 ...

  10. 匹夫细说C#:不是“栈类型”的值类型,从生命周期聊存储位置

    0x00 前言: 匹夫在日常和别人交流的时候,常常会发现一旦讨论涉及到“类型”,话题的热度就会立马升温,因为很多似是而非.或者片面的概念常常被人们当做是全面和正确的答案.加之最近在园子看到有人翻译的& ...

随机推荐

  1. VMware(虚拟机) 12版安装深度linux系统

    需要的工具: 1.VM ware workstation12虚拟机(可自行百度下载)  参考:VMware Workstation 12.5.5 官方中文正式版,下载地址:http://www.epi ...

  2. CF-787D-线段树建图+最短路

    http://codeforces.com/problemset/problem/787/D 题目大意是给出一个有向图,有N个节点,初始节点在S,询问S到所有点最短路.边的读入方式有三种, 1 u v ...

  3. Beta阶段——第1篇 Scrum 冲刺博客

    第1篇 Scrum 冲刺博客 a. 介绍小组新加入的成员,Ta担任的角色. 新加入成员 郭炜埕 原先担任的角色 前端界面设计 现在担任的角色 前端开发,并协助后端开发 新加成员介绍 炜埕同学对界面设计 ...

  4. Nginx配置——区分PC或手机访问不同域名

    新官网上线,但在手机上访问新官网的体验很差,要求在手机上访问新官网时访问旧官网,可以通过修改Nginx配置来实现自动跳转.首先是新官网的Nginx配置文件加个跳转判断,通过user-agent判断来源 ...

  5. Notes for GGplot2: Getting started with ggplot2

    Alpha-ma 2016/10/7 1 Introduction of GGplot2 ggplot2 is an R package for producing statistical, or d ...

  6. MySql习题和答案

    MySQL测试题 一.表关系请创建如下表,并创建相关约束 二.操作表 1.自行创建测试数据 2.查询“生物”课程比“物理”课程成绩高的所有学生的学号.ps:针对的是自己的生物成绩比物理成绩高,再把符合 ...

  7. volatile原理解析

    Java并发编程:volatile关键字解析 volatile 有序性.可见性 volatile可以保证一定程度上有序性,即volatile前面的代码先于后面的代码先执行. 但是前.后代码,各自里面的 ...

  8. mac bash 下使用vi 快捷方式——因为没有alt键 所以没有办法 用vi模式也非常方便的

    set -o emacs ##切到emacs模式 set -o vi ##切到vi模式 set -o ## 查看当前选项的设置状态 所以你只需要在.bashrc下加入 set -o vi 然后,使用E ...

  9. weblogic启动比一般机器慢原因

    weblogic启动慢一般先看setDomainEnv.sh中分配给JVM的内存大小,如果分配足够(没部应用一般也要1G以上)那么再用free -g看本机剩余内存是否充足.如果都没问题还是比一般机器启 ...

  10. window7下载安装桌面版ubuntu

    首先需要下载VMware Workstation   下载地址:http://pan.baidu.com/s/1qXS0rhi  秘钥:bbpn 我的环境是ubuntu-14.10-desktop-a ...