数据结构之栈详解(C语言手撕)

这篇具有很好参考价值的文章主要介绍了数据结构之栈详解(C语言手撕)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

数据结构之栈详解(C语言手撕),数据结构的学习之路,数据结构,c语言,c++,C语言,栈队列,后进先出

🎉个人名片:

🐼作者简介:一名乐于分享在学习道路上收获的大二在校生
🙈个人主页🎉:GOTXX
🐼个人WeChat:ILXOXVJE
🐼本文由GOTXX原创,首发CSDN🎉🎉🎉
🐵系列专栏:零基础学习C语言----- 数据结构的学习之路----C++的学习之路
🐓每日一句:如果没有特别幸运,那就请特别努力!🎉🎉🎉 ————————————————————————————

🎉文章简介

🎉本篇文章对 用C语言实现栈等相关知识 学习的相关知识进行分享!🎉💕

如果您觉得文章不错,期待你的一键三连哦,你的鼓励是我创作动力的源泉,让我们一起加油,一起奔跑,让我们顶峰相见!!!🎉🎉🎉
————————————————

一.栈的概念及结构

1.1栈的概念

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

压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶;
出栈:栈的删除操作叫做出栈。出数据也在栈顶;

1.2栈的结构

数据结构之栈详解(C语言手撕),数据结构的学习之路,数据结构,c语言,c++,C语言,栈队列,后进先出入数据和出数据都是从栈顶入和出;保持后进先出的原则*

1.3栈的实现

栈的实现:数组和链表都可以用来实现栈,保证先进后出原则;
数组:尾插就是进栈 尾删就是出栈(相比链表较为方便)
数据结构之栈详解(C语言手撕),数据结构的学习之路,数据结构,c语言,c++,C语言,栈队列,后进先出我这里定义的是Top指向的是栈顶元素的下一个位置

链表:可以选择头插进栈 头删出栈
如果选择的是尾插和尾删的话,需要找尾灯操作,不方便

数据结构之栈详解(C语言手撕),数据结构的学习之路,数据结构,c语言,c++,C语言,栈队列,后进先出

1.4栈的实现

数组实现栈(相对于链表,数组实现栈更优)

1.4.1功能函数的实现

一般的栈需要完成这几个函数

  1. 栈的初始化
  2. 栈的销毁
  3. 入栈
  4. 出栈
  5. 取栈顶元素
  6. 判断栈是否为空
void StackInit(ST* st);
void StackDestory(ST* st);

void StackPush(ST* st, STDateType x);
void StackPop(ST* st);

STDateType GetTop(ST* st);
bool StackEmpty(ST* st);

1.定义一个栈的结构体

这里我们实现的是动态的栈
typedef int STDateType;    //方便数据类型的替换
typedef struct Stack        
{
	STDateType* a;         //存储数据的数组
	int top;               
	int capacity;          //容量
}ST;

2.栈的初始化

这里top的初始化不同,top含义就不同;
1.如果top初始化给0,则每次入栈后top就会++;当入第一个数据时,top++后为1,则top含义为指向的是栈顶元素的下一个元素
2.如果top初始化为-1,则含义为指向栈顶元素
void StackInit(ST* st)
{
	assert(st);

	st->a = (STDateType* )malloc(4 * sizeof(STDateType));   
	if (st->a == NULL)
	{
		perror("malloc fail");
		exit(-1);
	}
	st->top = 0;             //指向栈顶元素的下一个位置
	st->capacity = 4;        //初始容量给4
}   


3.入栈函数

void StackPush(ST* st, STDateType x)
{
	assert(st);

	if (st->top == st->capacity)      //扩容逻辑与顺序表一样
	{
		//扩容
		STDateType* tmp = (STDateType* )realloc(st->a,sizeof(STDateType) * st->capacity *2);
		if (tmp == NULL)     
		{
			perror("malloc fail");
			exit(-1);
		}
		st->a = tmp;
		st->capacity *= 2;     //2倍扩容
	}

	st->a[st->top] = x;      //尾插数据
	st->top++;
}

4.出栈函数

直接将top--;top--后虽然数据没有改变,但是在下一次入栈时会将原数据给覆盖
void StackPop(ST* st)
{
	assert(st);

	st->top--;
}

5.获取栈顶元素

STDateType GetTop(ST* st)
{
	assert(st);
	assert(st->top);            //断言
	
	return st->a[st->top - 1];    //直接返回top后一个位置的元素
}

6.判断栈是否为空

bool StackEmpty(ST* st)
{
	assert(st);

	return st->top;      //返回栈的top,如果为0则为空   非0则不为空;
}

7.栈的销毁函数

void StackDestory(ST* st)
{
	assert(st);

	free(st->a);    //释放开辟的空间
	st->capacity = st->top = 0;    //置空
}

1.5总代码

#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>



typedef int STDateType;
typedef struct Stack
{
	STDateType* a;
	int top;
	int capacity;
}ST;

void StackInit(ST* st);
void StackDestory(ST* st);

void StackPush(ST* st, STDateType x);
void StackPop(ST* st);

STDateType GetTop(ST* st);
bool StackEmpty(ST* st);

#include"Stack.h"

void StackInit(ST* st)
{
	assert(st);

	st->a = (STDateType* )malloc(4 * sizeof(STDateType));
	if (st->a == NULL)
	{
		perror("malloc fail");
		exit(-1);
	}
	st->top = 0;
	st->capacity = 4;
}


void StackPush(ST* st, STDateType x)
{
	assert(st);

	if (st->top == st->capacity)
	{
		//扩容
		STDateType* tmp = (STDateType* )realloc(st->a,sizeof(STDateType) * st->capacity *2);
		if (tmp == NULL)
		{
			perror("malloc fail");
			exit(-1);
		}
		st->a = tmp;
		st->capacity *= 2;
	}

	st->a[st->top] = x;
	st->top++;
}

void StackPop(ST* st)
{
	assert(st);

	st->top--;
}

STDateType GetTop(ST* st)
{
	assert(st);
	assert(st->top);
	
	return st->a[st->top - 1];
}


bool StackEmpty(ST* st)
{
	assert(st);

	return st->top;
}

void StackDestory(ST* st)
{
	assert(st);

	free(st->a);
	st->capacity = st->top = 0;
}

数据结构之栈详解(C语言手撕),数据结构的学习之路,数据结构,c语言,c++,C语言,栈队列,后进先出文章来源地址https://www.toymoban.com/news/detail-841595.html

到了这里,关于数据结构之栈详解(C语言手撕)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构之栈与队列详解

    栈和队列是一种特殊的线性结构,他与之前学的线性结构不同,栈和队列是拥有一种特殊规则的线性结构,虽然它是用数组或者链表实现,但是只有符合这种规则才能被称作栈或者队列 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和

    2024年01月16日
    浏览(34)
  • C语言数据结构——线性表之栈和队列

    为什么会定义栈和队列这两种数据结构呢? 原因在于: 之所以会定义栈和队列这样的数据结构 是因为他们有两大特性 : 第一: 他们可以保存程序运行路径中各个点的信息,以便用于回溯操作或其他需要访问已经访问过的节点信息的操作。 比如: 栈用于解决迷宫问题,就

    2023年04月11日
    浏览(93)
  • 高效学习数据结构之栈和队列篇(五千字超详细教程)

    大家好呀我是小生🙉🙊🙈今天我们来学习 数据结构的栈和队列 ,小生为了方便大家理解特意附上了 许多图片和源码 一起加油吧 🥳🥳🥳   下面是我们今天要学习的内容 🥳🥳🥳  一.栈          1.🏠栈的基本概念 ​2.🏠栈的结构选择 🚀顺序表和链表的优缺点对比:

    2023年04月08日
    浏览(56)
  • 【高阶数据结构】手撕哈希表(万字详解)

    (꒪ꇴ꒪(꒪ꇴ꒪ )🐣,我是 Scort 目前状态:大三非科班啃C++中 🌍博客主页:张小姐的猫~江湖背景 快上车🚘,握好方向盘跟我有一起打天下嘞! 送给自己的一句鸡汤🤔: 🔥真正的大师永远怀着一颗学徒的心 作者水平很有限,如果发现错误,可在评论区指正,感谢🙏 🎉🎉

    2024年01月19日
    浏览(40)
  • 手撕哈希表(HashTable)——C++高阶数据结构详解

    小编是双非本科大一菜鸟不赘述,欢迎米娜桑来指点江山哦(QQ:1319365055) 🎉🎉非科班转码社区诚邀您入驻🎉🎉 小伙伴们,打码路上一路向北,彼岸之前皆是疾苦 一个人的单打独斗不如一群人的砥砺前行 这是我和梦想合伙人组建的社区,诚邀各位有志之士的加入!! 社

    2023年04月08日
    浏览(26)
  • 追梦之旅【数据结构篇】——C语言手撕八大经典排序

        😎博客昵称:博客小梦 😊最喜欢的座右铭:全神贯注的上吧!!! 😊作者简介:一名热爱C/C++,算法等技术、喜爱运动、热爱K歌、敢于追梦的小博主! 😘博主小留言:哈喽! 😄各位CSDN的uu们,我是你的博客好友小梦,希望我的文章可以给您带来一定的帮助,话不

    2024年02月17日
    浏览(34)
  • 数据结构入门(C语言版)一篇文章教会你手撕八大排序

    排序 :所谓排序,就是使一串记录,按照其中的某个或某些的大小,递增或递减的排列起来的操作。 稳定性 :假定在待排序的记录序列中,存在多个具有相同的的记录,若经过排序,这些记录的相对次序保持不变,即在原序列中,r[i]=r[j],且r[i]在r[j]之前,而

    2024年02月01日
    浏览(36)
  • 《数据结构与算法》之栈结构

    在计算机发明之初是为了计算,所以叫计算机,对我们给定的一个算式,然后给定的一套规则 加,减,乘,除,等,它就可以自己进行计算了,然后返回一个结果给我们 对于一般的算式 : 2+3+4 很显然,从左往右依次扫描,依次相加很简单的计算出来,因为它们是同级运算,

    2024年02月06日
    浏览(36)
  • [C语言实现]数据结构——手撕顺序栈之我出生就会写一个栈

    🥰作者: FlashRider 🌏专栏: 数据结构 目录 栈的前置知识 1.什么是栈? 2.生活中哪些地方有栈的影子? 顺序表实现栈 1.为什么通常采用顺序表实现栈? 2.栈的实现 栈( stack )又名堆栈,它是一种 运算受限的线性表 。限定仅在表尾进行插入和删除操作的线性表。这一端被称为

    2024年02月08日
    浏览(30)
  • 数据结构之栈

    栈是限定仅在表尾进行插入和删除操作的线性表,又称为后进先出(last in first out)的线性表(LIFO结构),表尾称为栈顶,表头称为栈底,不含元素则称为空栈; 抽象数据类型 : 其中base为NULL时表示栈结构不存在,top==base可作为栈空的标记; InitStack GetTop Push Pop 测试 链式存储便于多

    2024年02月05日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包