Day 7:栈

2024-09-06 12:04
文章标签 day

本文主要是介绍Day 7:栈,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

栈的原理

        定义:栈是限制在一端进行插入操作和删除操作线性表(俗称堆栈)。

        栈顶:允许进行操作的一端。

        空栈:当栈中没有元素。

        栈底:另一固定端.

        特点:后进先出。(后面进去的元素先出去。如:an)

        核心问题:检查是否出现回路,例如:C0->C5->C6->C7->C0。

        和栈的关系:先把C0、C1(即没有前驱的元素)放入栈,再取出。依次执行上述操作。(第二次没有前驱的元素就是C2、C3。)

        想象成从A地前往D地,到达D地后返回A地的过程。 

顺序栈

        定义

        具有顺序表同样的存储结构,由数组定义,配合用数组下标表示的栈顶指针top(相对指针)完成各种操作。

        栈的实现

                结构体创建

typedef int data_t;
typedef struct
{data_t * date;/*用指针指向栈的存储空间*/int maxlen;	  /*当前栈最大存储元素个数(特点:提供用户可以以参数的形式提供个数)*/int top;	  /*指示栈顶位置的变量(数组下标)*/
}sqstack;

                创建栈

sqstack* stack_create(int maxlen)
{	/*1.malloc sqstack内存空间:存放指向栈的指针,栈顶位置,最大存储个数*/sqstack* s = malloc(sizeof(sqstack));	/*2.malloc data内存空间:存放栈的数据*/s->date = malloc(maxlen*sizeof(data_t));if (s == NULL || s->date == NULL){return NULL;}/*3.初始化*/memset(s->date, 0, maxlen*sizeof(data_t);s->maxlen = maxlen;s->top = -1;return s;
}

                入栈

        整体思路:

        1.检查栈是否满?

        2.top++;

        3.data[top]=value;

stack_push(sqstack* s, data_t value)
{/*检查栈满?*/if (s->top == s->maxlen-1){return -1;}s->top = s->top + 1;s->date[top] = value;return 0;
}

                 栈空or栈满

/*full or empty == 1*/
int stack_empty(sqstack* s)
{if (s->top == -1){printf("empty!\n");return 1;}return 0;
}
int stack_full(sqstack* s)
{if (s->top == s->maxlen - 1){printf("full");return 1;}return 0;
}

                出栈 

int stack_pop(sqstack* s)
{if (s->top == -1){return -1;}s->top = s->top - 1;return s->date[s->top+1];
}

                查看栈顶 

int stack_top(sqstack* s)
{return s->date[s->top];
}

                栈清空 

int stack_clear(sqstack* s)
{if (s == NULL){return -1;}s->top = 1;return 0;
}

                栈释放

int stack_free(sqstack* s)
{/*核心逻辑:先释放后申请的内存空间(因为释放先申请的内存空间就无法找到后申请的地址)*/if (s == NULL){return -1;}if (s->date != NULL){free(s->date);}free(s);return 0;
}

 链式栈

        

        

这篇关于Day 7:栈的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1141956

相关文章

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*

Linux基础入门 --9 DAY

文本处理工具之神vim         vi和vim简介 一、vi编辑器 vi是Unix及类Unix系统(如Linux)下最基本的文本编辑器,全称为“visual interface”,即视觉界面。尽管其名称中包含“visual”,但vi编辑器实际上工作在字符模式下,并不提供图形界面。vi编辑器以其强大的功能和灵活性著称,是Linux系统中不可或缺的工具之一。 vi编辑器具有三种主要的工作模

day-50 求出最长好子序列 I

思路 二维dp,dp[i][h]表示nums[i] 结尾,且有不超过 h 个下标满足条件的最长好子序列的长度(0<=h<=k),二维数组dp初始值全为1 解题过程 状态转换方程: 1.nums[i]==nums[j],dp[i,h]=Math.max(dp[i,h],dp[j,h]+1) 2.nums[i]!=nums[j],dp[i,h]=Math.max(dp[i,h],dp[j,h-1

[Day 73] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

AI在健康管理中的應用實例 1. 引言 隨著健康管理需求的提升,人工智能(AI)在該領域的應用越來越普遍。AI可以幫助醫療機構提升效率、精準診斷疾病、個性化治療方案,以及進行健康數據分析,從而改善病患的健康狀況。這篇文章將探討AI如何應用於健康管理,並通過具體代碼示例說明其技術實現。 2. AI在健康管理中的主要應用場景 個性化健康建議:通過分析用戶的健康數據,如飲食、運動、睡眠等,AI可

Vue day-03

目录 Vue常用特性 一.响应更新 1. 1 v-for更新监测 1.2 v-for就地更新 1.3 什么是虚拟DOM 1.4 diff算法更新虚拟DOM 总结:key值的作用和注意点: 二.过滤器 2.1 vue过滤器-定义使用 2.2 vue过滤器-传参和多过滤器 三. 计算属性(computed) 3.1 计算属性-定义使用 3.2 计算属性-缓存 3.3 计算属

用Python实现时间序列模型实战——Day 14: 向量自回归模型 (VAR) 与向量误差修正模型 (VECM)

一、学习内容 1. 向量自回归模型 (VAR) 的基本概念与应用 向量自回归模型 (VAR) 是多元时间序列分析中的一种模型,用于捕捉多个变量之间的相互依赖关系。与单变量自回归模型不同,VAR 模型将多个时间序列作为向量输入,同时对这些变量进行回归分析。 VAR 模型的一般形式为: 其中: ​ 是时间  的变量向量。 是常数向量。​ 是每个时间滞后的回归系数矩阵。​ 是误差项向量,假

Linux基础入门 --8 DAY

文件权限管理 设置文件的所有者chown         格式: chown [OPTION]... [OWNER][:[GROUP]] FILE... chown [OPTION]... --reference=RFILE FILE...         示例:  chown admin(所有者):admin(所属组)f1.txt chown admin(所有者).admin(

[Day 72] 區塊鏈與人工智能的聯動應用:理論、技術與實踐

區塊鏈在跨境支付中的應用 跨境支付一直是全球經濟中極具挑戰的領域。傳統的跨境支付系統通常需要數天時間來處理交易,涉及的中間機構多且手續費昂貴。然而,區塊鏈技術的出現為解決這些問題提供了一條嶄新的途徑。本文將探討區塊鏈在跨境支付中的應用,並通過代碼示例展示如何使用區塊鏈技術來優化跨境支付流程。 1. 區塊鏈在跨境支付中的優勢 區塊鏈技術具有去中心化、透明、高效和安全等特性,使其在跨境支付領域具

代码随想录Day 36|滑铁卢了,leetcode题目:1049.最后一块石头的重量、494.目标和、474.一和零

提示:DDU,供自己复习使用。欢迎大家前来讨论~ 文章目录 动态规划一、题目题目一:1049.最后一块石头的重量II解题思路: 题目二:494.目标和动态规划 (二维dp数组)#动态规划 (一维dp数组) 题目三: 474.一和零解题思路: 总结 动态规划 有点难了,之前差的有点多,找时间补 一、题目 题目一:1049.最后一块石头的重量II leetcode题目链接

嵌入式软件--51单片机 DAY 4

一、蜂鸣器 当电流通过线圈时会产生电磁场,电磁场与永磁体相互作用,从而使金属膜产生震动而发声。为使金属膜持续震动,蜂鸣器需要使用震荡电路进行驱动。有些蜂鸣器元件内部自带震荡驱动电路,这种蜂鸣器叫做有源蜂鸣器(Active Buzzer,自激式蜂鸣器);而有些则不带震荡驱动电路,这种蜂鸣器叫做无源蜂鸣器(Passive Buzzer,它激式蜂鸣器)。 1.原理图 2.软件实现 Int_B