栈的数组实现

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. Wannafly挑战赛29-A/B

    链接:https://ac.nowcoder.com/acm/contest/271/A来源:牛客网 御坂美琴 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语言 ...

  2. PinkEx专用图标

  3. java.lang.Exception: DEBUG STACK TRACE for PoolBackedDataSource.close().

    java.lang.Exception: DEBUG STACK TRACE for PoolBackedDataSource.close(). java.lang.Exception: DEBUG ...

  4. iOS block 机制

    本文要将block的以下机制,并配合具体代码详细描述: block 与 外部变量 block 的存储域:栈块.堆块.全局块 定义 块与函数类似,只不过是直接定义在另一个函数里,和定义它的那个函数共享同 ...

  5. Oracle物理DG自动切换——Dataguard Broker配置

    1.前言部分 1.1 导读 各位技术爱好者,看完本文后,你可以掌握如下的技能: ① Data Guard Broker 的配置 ② Fast-Start Failover 的配置 ③ Oracle D ...

  6. EvalAI使用——类似kaggle的开源平台,不过没有kernel fork功能,比较蛋疼

    官方的代码 https://github.com/Cloud-CV/EvalAI 我一直没法成功import yaml配置举办比赛(create a challenge on EvalAI 使用htt ...

  7. 撤销commit

    如果不小心commit了一个不需要commit的文件,可以对其进行撤销. 先使用git log 查看 commit日志 commit 422bc088a7d6c5429f1d0760d008d86c5 ...

  8. vue中nextTick和$nextTick的差别

    <ul id="demo">     <li v-for="item in list">{{item}}</div> < ...

  9. RWCString 定义 memeroy leak

    代码截取片段: testDefs.hh class testDefs { public: static const RWCString testStr; }; testDefs.cc const RW ...

  10. VMware 安装 centos,自定义分区

    具体查看:https://jingyan.baidu.com/album/6525d4b1799149ac7d2e9483.html?picindex=11