听黑马程序员教程《基础数据结构和算法 (C版本)》,

照着老师所讲抄的,

视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1

喜欢的朋友可以去看看,欢迎大家一起交流学习。

/*
    栈的顺序存储:
        栈的顺序存储结构简称【顺序栈】,它是运算受限制的顺序表。
        顺序栈的存储结构是:利用一组地址连续的存储单元依次存放自栈底到栈顶的
        数据元素,同时附设指针top只是栈顶元素在顺序表中的位置。
    设计与实现:
        因为栈是一种特殊的线性表,所以栈的顺序存储可以通过顺序线性表来实现。
    笔记:
        先进后出规则,从栈顶进入,到栈底,
        不能遍历。压栈,入栈。出栈(top方法)。
        栈,栈容器,只要符合先进后出规则,它就是一个栈容器。
        其实栈也就是个链表,只是只能从一端插入或删除。
        
*/

栈的顺利存储main.c

 1 #include<stdio.h>
2 #include<stdlib.h>
3 #include<string.h>
4 #include "SeqStack.c"
5
6 /*
7 栈的顺序存储:
8 栈的顺序存储结构简称【顺序栈】,它是运算受限制的顺序表。
9 顺序栈的存储结构是:利用一组地址连续的存储单元依次存放自栈底到栈顶的
10 数据元素,同时附设指针top只是栈顶元素在顺序表中的位置。
11 设计与实现:
12 因为栈是一种特殊的线性表,所以栈的顺序存储可以通过顺序线性表来实现。
13 笔记:
14 先进后出规则,从栈顶进入,到栈底,
15 不能遍历。压栈,入栈。出栈(top方法)。
16 栈,栈容器,只要符合先进后出规则,它就是一个栈容器。
17 其实栈也就是个链表,只是只能从一端插入或删除。
18
19 */
20
21
22 // 用户数据
23 typedef struct PERSON{
24 char name[32];
25 int age;
26 }Person;
27
28 int main(){
29 printf("好好学习,天天向上~!\t\t\t 栈的顺利存储 20220606\n\n\n");
30
31 // 创建栈
32 SeqStack* stack = Init_SeqStack();
33
34 // 创建数据
35 Person p1 = {"pp1",10};
36 Person p2 = {"pp2",10};
37 Person p3 = {"pp3",10};
38 Person p4 = {"pp4",10};
39 Person p5 = {"pp5",10};
40 Person p6 = {"pp6",10};
41 Person p7 = {"pp7",10};
42 Person p8 = {"pp8",10};
43 Person p9 = {"pp9",10};
44 Person p10 = {"pp10",10};
45 Person p11 = {"pp11",10};
46
47 // 入栈
48 Push_SeqStack(stack,&p1);
49 Push_SeqStack(stack,&p2);
50 Push_SeqStack(stack,&p3);
51 Push_SeqStack(stack,&p4);
52 Push_SeqStack(stack,&p5);
53 Push_SeqStack(stack,&p6);
54 Push_SeqStack(stack,&p7);
55 Push_SeqStack(stack,&p8);
56 Push_SeqStack(stack,&p9);
57 Push_SeqStack(stack,&p10);
58 Push_SeqStack(stack,&p11);
59
60 // 输出
61 while(Size_SeqStack(stack)>0){
62 // 访问栈顶元素
63 Person* p = (Person*)Top_SeqStack(stack);
64 printf("p_name:%-4s - p_age:%-4d \n",p->name,p->age);
65 // 出栈
66 Pop_SeqStack(stack);
67
68 }
69
70 // 释放内存
71 FreeSpace_SeqStack(stack);
72
73
74 printf("\n\n");
75 return 0;
76 }

SeqStack.h

 1 #ifndef SEQSTACK_H
2 #define SEQSTACK_H
3
4 #include<stdio.h>
5 #include<stdlib.h>
6
7
8 // 用数组模拟栈的顺序存储(栈顶设在数组右边,从右边入和出。类似链表尾插法 )
9
10 #define MAX_SIZE 1024
11 #define SEQSTACK_TRUE 1
12 #define SEQSTACK_FALSE 0
13
14 typedef struct SEQSTACK{
15 void* data[MAX_SIZE];
16 int size;
17 }SeqStack;
18
19
20 // 初始化栈
21 SeqStack* Init_SeqStack();
22
23 // 入栈(尾插法),参数:栈,插入值。
24 void Push_SeqStack(SeqStack* stack,void* data);
25
26 // 返回栈顶元素
27 void* Top_SeqStack(SeqStack* stack);
28
29 // 出栈(删除最后元素)
30 void Pop_SeqStack(SeqStack* stack);
31
32 // 判断是否为空
33 int IsEmpty(SeqStack* stack);
34
35 // 返回栈中元素个数
36 int Size_SeqStack(SeqStack* stack);
37
38 // 清空栈
39 void Clear_SeqStack(SeqStack* stack);
40
41 // 销毁
42 void FreeSpace_SeqStack(SeqStack* stack);
43
44 #endif

SeqStack.c

  1 #include "SeqStack.h"
2
3 // 初始化栈
4 SeqStack* Init_SeqStack(){
5
6 SeqStack* stack = (SeqStack*)malloc(sizeof(SeqStack));
7 int i;
8 for(i=0;i<MAX_SIZE;i++){
9 stack->data[i] = NULL;
10 }
11 stack->size = 0;
12 // 这个栈就是一个数组结构体,里面有MAX_SIZE(1024)个数组元素。创建结构体后
13 // 把里面1024个元素都设为NULL,同时size也设为0
14 return stack;
15 }
16
17 // 入栈(尾插法),参数:栈,插入值。
18 void Push_SeqStack(SeqStack* stack,void* data){
19
20 if(stack==NULL){
21 return;
22 }
23 if(data==NULL){
24 return;
25 }
26 if(stack->size == MAX_SIZE){ // 元素个数和数组下标相等:放满了,放不下了。
27 return;
28 }
29
30 // 插入到最后。
31 // 【【【【【 size即标记当前元素个数,同时也标记着最后位置】】】】
32 stack->data[stack->size] = data;
33
34 // 标记+1
35 stack->size++;
36
37 }
38
39 // 返回栈顶元素
40 void* Top_SeqStack(SeqStack* stack){
41
42 if(stack==NULL){
43 return;
44 }
45 if(stack->size ==0){
46 return;
47 }
48
49 return stack->data[stack->size -1]; // 减1,因为数组是从0开始。
50
51 }
52
53 // 出栈(删除最后元素)
54 void Pop_SeqStack(SeqStack* stack){
55 if(stack==NULL){
56 return;
57 }
58 if(stack->size ==0){
59 return;
60 }
61
62 stack->data[stack->size -1] = NULL;
63 // 也可以置空,也可以不必置空,因为下面size-1了
64
65 stack->size--;
66
67 }
68
69 // 判断是否为空
70 int IsEmpty(SeqStack* stack){
71
72 if(stack == NULL){
73 return -1;
74 }
75 if(stack->size == 0){
76 return SEQSTACK_FALSE;
77 }
78
79 return SEQSTACK_TRUE;
80 }
81
82 // 返回栈中元素个数
83 int Size_SeqStack(SeqStack* stack){
84
85 if(stack==NULL){
86 return;
87 }
88
89 return stack->size;
90 }
91
92 // 清空栈
93 void Clear_SeqStack(SeqStack* stack){
94
95 if(stack == NULL){
96 return;
97 }
98
99 int i;
100 for(i=0;i<stack->size;i++){
101 stack->data[i] = NULL;
102 }
103 // 上面可以把每个元素都置NULL,也可以不必置NULL,因为下面size=0了。
104
105 stack->size = 0;
106
107 }
108
109 // 销毁
110 void FreeSpace_SeqStack(SeqStack* stack){
111
112 if(stack == NULL){
113 return;
114 }
115
116 free(stack);
117
118 }

C语言- 基础数据结构和算法 - 栈的顺序存储的更多相关文章

  1. C语言- 基础数据结构和算法 - 栈的链式存储

    听黑马程序员教程<基础数据结构和算法 (C版本)>, 照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友 ...

  2. C语言- 基础数据结构和算法 - 队列的顺序存储

    听黑马程序员教程<基础数据结构和算法 (C版本)>, 照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友 ...

  3. C语言- 基础数据结构和算法 - 09 栈的应用_中缀表达式转后缀表达式20220611

    09 栈的应用_中缀表达式转后缀表达式20220611 听黑马程序员教程<基础数据结构和算法 (C版本)>, 照着老师所讲抄的, 视频地址https://www.bilibili.com/ ...

  4. C语言- 基础数据结构和算法 - 08 栈的应用_就近匹配20220611

    听黑马程序员教程<基础数据结构和算法 (C版本)>, 照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友 ...

  5. C语言- 基础数据结构和算法 - 循环链表

    听黑马程序员教程<基础数据结构和算法 (C版本)>,照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友可 ...

  6. C语言 - 基础数据结构和算法 - 企业链表

    听黑马程序员教程<基础数据结构和算法 (C版本)>,照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友可 ...

  7. C语言 - 基础数据结构和算法 - 单向链表

    听黑马程序员教程<基础数据结构和算法 (C版本)>,照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友可 ...

  8. C语言- 基础数据结构和算法 - 动态数组

    听黑马程序员教程<基础数据结构和算法 (C版本)>,照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友可 ...

  9. 大数据技术之_16_Scala学习_13_Scala语言的数据结构和算法_Scala学习之旅收官之作

    第十九章 Scala语言的数据结构和算法19.1 数据结构(算法)的介绍19.2 看几个实际编程中遇到的问题19.2.1 一个五子棋程序19.2.2 约瑟夫问题(丢手帕问题)19.2.3 其它常见算法 ...

随机推荐

  1. Node.js躬行记(17)——UmiJS版本升级

    在2020年我刚到公司的时候,公司使用的版本还是1.0,之后为了引入微前端,迫不得已被动升级. 一.从 1.0 到 2.0 在官方文档中,有专门一页讲如何升级的,这个用户体验非常好. 一个清单列的非常 ...

  2. PyQt5 基础知识(六):展示控件

    目录 3. 展示控件 3.1 QLabel 3.1.1 描述 3.1.2 功能作用 3.1.2.1 基本功能 3.1.2.2 文本交互 3.1.2.3 内容操作 3.1.2.3.1 文本字符串 3.1 ...

  3. Apache Zookeeper 使用-安装

    Apache Zookeeper 使用-安装 官方网站 https://zookeeper.apache.org/ 官方文档 下载地址 Zookeeper 是什么? ZooKeeper is a ce ...

  4. 帝国CMS灵动标签调用包含指定短语关键词关键字文章的语法

    [e:loop={"select * from phome_ecms_news where title like '%这里是关键词%' and checked=1 order by news ...

  5. drf路由组件(4星)

    路由组件(4星) 路由Routers 对于视图集ViewSet, 我们除了可以自己手动指明请求方式与动作action之间的对应关系外,还可以使用Routers来帮助我们快速实现路由信息. REST f ...

  6. 【.NET6+Modbus】Modbus TCP协议解析、仿真环境以及基于.NET实现基础通信

    前言:随着工业化的发展,目前越来越多的开发,从互联网走向传统行业.其中,工业领域也是其中之一,包括各大厂也都在陆陆续续加入工业4.0的进程当中. 工业领域,最核心的基础设施,应该是与下位硬件设备或程序 ...

  7. HCIE-SEC笔记-第四节-网络入侵和防火墙基础

    等级保护: 网络安全:防火墙.VPN.准入控制 渗透测试: 防火墙:区域隔离和访问控制 数字与研究公司:用数据说话 IDC:国际数据公司 Gartner:著名的数字与咨询公司 弗雷斯特: 数世咨询: ...

  8. 2021.07.20 P3951 小凯的疑惑(最大公因数,未证)

    2021.07.20 P3951 小凯的疑惑(最大公因数,未证) 重点: 1.最大公因数 题意: 求ax+by最大的表示不了的数(a,b给定 x,y非负). 分析: 不会.--2021.07.20 代 ...

  9. mmdetection训练出现nan

    训练出现nan 在使用MMDetection训练模型时,发现打印信息中出现了很多nan.现象是,loss在正常训练下降的过程中,突然变为nan. 梯度裁减 在模型配置中加上grad_clip: opt ...

  10. marginStart marginEnd就关于上述两个用法展开讨论

    在我还在手动调整两个控件距离时,第一次见识到了marginStart marginEnd两个用法, 但是,只知道它俩能够调整控件距离,但是不知道具体用法,老师也没细说,就这样开启了我对于这两个用法&q ...