数据结构(三)------栈

news/2025/1/11 14:52:48/

制作不易,三连支持一下呗!!!

文章目录

  • 前言
  • 一、什么是栈
  • 二、栈的实现
    • 1.栈的结构
    • 2.栈的初始化和销毁
    • 3.栈的插入数据和删除数据
    • 4.取栈顶元素
  • 总结


前言

前面我们介绍了第二种数据结构---链表,这里我们继续介绍下一种数据结构——栈!!!


一、什么是栈

栈:栈是一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作,进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出(Last In First Out)原则。

压栈:栈的插入操作叫做进栈 / 压栈 / /入栈。

出栈:栈的删除操作叫做出栈。

二、栈的实现

1.栈的结构

栈的底层既可以用顺序表的结构来存储数据,也可以用链表的形式存储数据,但是我们一般选择顺序表。

原因:如果用链表,对于删除操作,我们就需要找到最后一个元素的前一个元素,要么用循环遍历的方式来找,这样时间复杂度为o(N),效率不高,要么使用双向链表,相较于顺序表在空间上浪费了一些。同时,由于CPU高速缓存的局部性原理,数组是连续空间在访问时效率更高!!!

注:如果非要用链表来实现栈,那么推荐用栈的插入推荐用单链表的头插和头删,这样避免了我们在删除时寻找倒数第二个节点的麻烦。

根据我们的推导:

栈的结构:

#define STDateType inttypedef struct Stack
{STDateType* a;int top;int capacity;
}ST;

2.栈的初始化和销毁

1.初始化:

void STInit(ST* ps)
{assert(ps);ps->a = NULL;ps->top = 0;ps->capacity = 0;
}

二:销毁 

void STDestroy(ST* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->top = ps->capacity = 0;
}

3.栈的插入和删除

1.插入数据

void STPush(ST* ps, STDateType x)
{assert(ps);if (ps->top == ps->capacity){int newcapacity = ps->capacity == 0 ? 4 : ps->capacity * 2;STDateType* tmp = (STDateType*)realloc(ps->a, newcapacity * sizeof(STDateType));if (tmp == NULL){perror("realloc:");return;}ps->a = tmp;ps->capacity = newcapacity;}ps->a[ps->top] = x;ps->top++;}

 学习链表后,栈的插入和删除操作应该相对要更简单一些,这里就不做过多讲解了。


2.删除数据

删除数据时,需要检查栈是否为空,如果为空就不能再删除了

这里我们又实现了一个检查栈是否为空的函数:

bool STEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}

 

删除数据:

void STPop(ST* ps)
{assert(ps);assert(!STEmpty(ps));ps->top--;
}

4.取栈顶元素

这里特别要注意的是,因为我们在初始化时给top的值为0,也就是说这里top表示的是栈顶元素的下一个。因此栈顶元素的下标是top-1。

注:这里初始化时也可以讲top初始化成-1,这样top表示的就是栈顶元素。插入数据就是先+1再插入。两种写法都可以,无优劣之分。

STDateType STTop(ST* ps)
{assert(ps);assert(!STEmpty(ps));return ps->a[ps->top - 1];
}


总结

栈的实现相较于链表还是很简单的,如果有些地方不太理解,可以去看看链表部分。

全部代码:

#define STDateType inttypedef struct Stack
{STDateType* a;int top;int capacity;
}ST;void STInit(ST* ps)
{assert(ps);ps->a = NULL;ps->top = 0;ps->capacity = 0;
}void STDestroy(ST* ps)
{assert(ps);free(ps->a);ps->a = NULL;ps->top = ps->capacity = 0;
}void STPush(ST* ps, STDateType x)
{assert(ps);if (ps->top == ps->capacity){int newcapacity = ps->capacity == 0 ? 4 : ps->capacity * 2;STDateType* tmp = (STDateType*)realloc(ps->a, newcapacity * sizeof(STDateType));if (tmp == NULL){perror("realloc:");return;}ps->a = tmp;ps->capacity = newcapacity;}ps->a[ps->top] = x;ps->top++;}void STPop(ST* ps)
{assert(ps);assert(!STEmpty(ps));ps->top--;
}bool STEmpty(ST* ps)
{assert(ps);return ps->top == 0;
}int STSize(ST* ps)
{assert(ps);return ps->top;
}STDateType STTop(ST* ps)
{assert(ps);assert(!STEmpty(ps));return ps->a[ps->top - 1];
}


http://www.ppmy.cn/news/1451003.html

相关文章

微隔离实施五步法,让安全防护转起来

前言 零信任的最核心原则→最小权限 安全的第一性原理→预防 零信任的最佳实践→微隔离 “零信任”这个术语的正式出现,公认是在2010年由Forrester分析师John Kindervag最早提出。时至今日,“零信任”俨然已成安全领域最热门的词汇,做安全…

Jetpack Compose简介

文章目录 Jetpack Compose简介概述声明式UI和命令式UIJetpack Compose和Android View对比Compose API设计原则一切皆为函数组合优于继承单一数据源 Jetpack Compose和Android View关系使用ComposesetContent()源码ComposablePreview Jetpack Compose简介 概述 Jetpack Compos…

Spring Boot中使用Redis和Lua脚本实现延时队列

码到三十五 : 个人主页 延时队列是一种常见的需求。延时队列允许我们延迟处理某些任务,这在处理需要等待一段时间后才能执行的操作时特别有用,如发送提醒、定时任务等。文中,将介绍如何在Spring Boot环境下使用Redis和Lua脚本来实…

使用 SSH 密钥配置 Git 账号需要以下步骤

1、生成 SSH 密钥: 如果你还没有 SSH 密钥,可以使用以下命令在电脑终端中生成一个新的 SSH 密钥: ssh-keygen -t rsa -b 4096 -f /Users/XXXX/.ssh/id_rsa_my_personal -C "your_emailexample.com" ssh-keygen 是用于生成 SSH 密…

---文件操作---

#include<iostream> using namespace std; #include<fstream>void test01() {//1.包含头文件//2.创建流对象ofstream ofs;//3.指定打开方式ofs.open("test.txt", ios::out);//写文件//4.写内容ofs << "张三" << endl;ofs <<…

ArmSoM-Sige5 RK3576开发板 正式发布!

简介​ ArmSoM-Sige5 采用Rockchip RK3576第二代8nm高性能AIOT平台&#xff0c;6 TOPS算力NPU&#xff0c;最大可配16GB大内存。支持8K视频编解码&#xff0c;拥有丰富的接口&#xff0c;支持双千兆网口&#xff0c;WiFi6 & BT5和多种视频输出。支持多种操作系统&#xff…

每日一题-贪心算法

目录 前言 买入股票的最佳时机(1) 买入股票的最好时机(2) 前言 当你踏上贪心算法的旅程&#xff0c;仿佛置身于一场智慧的盛宴&#xff0c;每一步都是对问题解决方案的审慎选择&#xff0c;每一次决策都是对最优解的向往。贪心算法以其简洁高效的特性&#xff0c;被广泛运用于…

MySQL常见问题解决和自动化安装脚本

常见问题 MySQL密码正确但无法登录的情况 这种情况一般都是因为缓存&#xff0c;使用mysql -u root -p123456直到成功登陆为止&#xff0c;并且进入之后重新修改密码&#xff0c;多次重复修改密码的命令并且再一次清除缓存后退出。 ALTER USER rootlocalhost IDENTIFIED WIT…