【算法与数据结构】栈

news2024/11/18 15:40:32

栈:结构定义

放入元素是从底向上放入
有一个栈顶指针,永远处在栈顶的元素
还需要标记栈大小的size
栈的性质: Fisrt-in Last-out (FILO) 先进后出
栈改变元素的顺序

在这里插入图片描述

栈:出栈

让栈顶指针向下移动一位
在这里插入图片描述

栈:入栈

栈顶指针向上移动一位,然后把元素放进来
在这里插入图片描述

栈:数组实现

结构定义


typedef struct Stack{
	int *data;
	int size, top;
} Stack;

初始化栈
top指针一开始指向-1

Stack *initStack(int n)
{
	Stack *s = (Stack*)malloc(sizeof(Stack));
	s->data = (int *)malloc(sizeof(int)* n);
	s->size = n;
	s->top = -1;
	return s;
}

栈判空

// 栈判空
int empty(Stack *s)
{
	return s->top == -1;
}

查看栈顶元素

// 查看栈顶元素
int top(Stack *s)
{
	if (empty(s)) return 0;
	return s->data[s->top]; 
}

入栈

// 入栈
int push(Stack *s, int val)
{
	if (s->top + 1 == s->size) return 0;  // 栈是否满了
	s->top += 1;
	s->data[s->top] = val;
	return 1;


}

出栈

// 出栈
int pop(Stack *s)
{
	if (empty(s)) return 0;
	s->top -= 1;
	return 1;
}

销毁栈

// 销毁栈
void clearStack(Stack *s)
{
	if (s == NULL) return;
	free(s->data);
	free(s);
	return;
}

栈:代码演示

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <iostream>



typedef struct Stack{
	int *data;
	int size, top;
} Stack;


Stack *initStack(int n)
{
	Stack *s = (Stack*)malloc(sizeof(Stack));
	s->data = (int *)malloc(sizeof(int)* n);
	s->size = n;
	s->top = -1;
	return s;

}

// 栈判空
int empty(Stack *s)
{
	return s->top == -1;
}

// 查看栈顶元素
int top(Stack *s)
{
	if (empty(s)) return 0;
	return s->data[s->top]; 
}
// 入栈
int push(Stack *s, int val)
{
	if (s->top + 1 == s->size) return 0;  // 栈是否满了
	s->top += 1;
	s->data[s->top] = val;
	return 1;


}

// 出栈
int pop(Stack *s)
{
	if (empty(s)) return 0;
	s->top -= 1;
	return 1;
}


// 销毁栈
void clearStack(Stack *s)
{
	if (s == NULL) return;
	free(s->data);
	free(s);
	return;
}

// 输出栈
void outputStack(Stack *s)
{
	printf("Stack:  ");
	for (int i = s->top; i >= 0; --i)
	{
		printf("%4d", s->data[i]);
	}
	printf("\n\n");
	return;
}

int main()
{
	srand(time(0));
    #define MAX_OP 10
	Stack *s = initStack(MAX_OP);
	for (int i = 0; i < MAX_OP; i++)
	{
		int op = rand() % 3, val = rand() % 100;    // 0: pop;  1, 2: push
		switch (op)
		{
		case 0:
			printf("pop stack, item = %d\n", top(s));
			pop(s);
			break;
		case 1:
		case 2:
			printf("push stack, item = %d\n", val);
			push(s, val);
			break;

		}
		outputStack(s);
	}

	clearStack(s);

	std::cin.get();
	return 0;
}

测试结果

在这里插入图片描述

Leetcode-20. 有效的括号

给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
  3. 每个右括号都有一个对应的相同类型的左括号。

示例 1:

输入:s = “()”
输出:true

示例 2:

输入:s = “()[]{}”
输出:true

示例 3:

输入:s = “(]”
输出:false

提示:

1 <= s.length <= 104
s 仅由括号 ‘()[]{}’ 组成

题目解析

怎么判断一个括号序列满足相互包含的相互关系?

在这里插入图片描述
一开始,top指针指向-1
在这里插入图片描述
碰到左括号"(“,入栈
在这里插入图片描述
遇到左括号”{“,继续入栈
在这里插入图片描述
遇到右括号,且匹配得上栈顶元素,出栈
在这里插入图片描述
遇到右括号,且匹配得上栈顶元素,继续出栈
在这里插入图片描述
遇到左括号“[”,入栈
在这里插入图片描述
遇到左括号”(“,继续入栈
在这里插入图片描述
遇到右括号,且与栈顶元素匹配,出栈
在这里插入图片描述
遇到左括号”{",入栈
在这里插入图片描述
遇到右括号,且与栈顶元素匹配,出栈
在这里插入图片描述

遇到右括号,且与栈顶元素匹配,出栈
在这里插入图片描述

最后,栈为空,判定括号序列合法

代码演示

先改写栈的代码,将其从int类型全部改为char类型

typedef struct Stack{
	char *data;
	int size, top;
} Stack;


Stack *initStack(int n)
{
	Stack *s = (Stack*)malloc(sizeof(Stack));
	s->data = (char *)malloc(sizeof(char)* n);
	s->size = n;
	s->top = -1;
	return s;

}

// 栈判空
int empty(Stack *s)
{
	return s->top == -1;
}

// 查看栈顶元素
char top(Stack *s)
{
	if (empty(s)) return 0;
	return s->data[s->top];
}
// 入栈
int push(Stack *s, char val)
{
	if (s->top + 1 == s->size) return 0;  // 栈是否满了
	s->top += 1;
	s->data[s->top] = val;
	return 1;


}

// 出栈
int pop(Stack *s)
{
	if (empty(s)) return 0;
	s->top -= 1;
	return 1;
}


// 销毁栈
void clearStack(Stack *s)
{
	if (s == NULL) return;
	free(s->data);
	free(s);
	return;
}

主程序代码

void solve(char str[])
{
	int flag = 1;    // 是否匹配成功
	Stack *s = initStack(100);

	// 扫描字符串的每一位
	for (int i = 0; str[i]; i++)
	{
		if (str[i] == '(' || str[i] == '[' || str[i] == '{')
		{
			push(s, str[i]);
		}
		else
		{
			// 判断是否与栈顶元素匹配
			switch (str[i])
			{
			case ')':
				if (top(s) == '(') pop(s); 
				else flag = 0;     // 没有匹配成功
				break;
			case ']': 
				if (top(s) == '[') pop(s);
				else flag = 0;   
				break;
			case '}':
				if (top(s) == '{') pop(s);
				else flag = 0;
				break;
			}
			if (flag == 0) break;
		}
		
	}
	if (flag == 0 || !empty(s)) printf("error");
	else printf("success\n");
	clearStack(s);
}

int main()
{
	
	char str[100];
	while (scanf_s("%s", str))
	{
		solve(str);
	}
	


	std::cin.get();
	return 0;
}

输入1:([{}]){{{[]}}}{}
输出1:success: ([{}]){{{[]}}}{}

输入2: ((((([]{}[]{}
输出2: error: ((((([]{}[]{}

输入3: (([]{}))))
输出3: error: (([]{}))))

总结

栈的作用:判断括号序列是否合法
括号序列本身是一个完全包含关系,栈就是可以处理这种具有完全包含关系的问题。

参考

ACM大牛带你玩转算法与数据结构

Leetcode

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/517340.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【JavaEE】SpringMVC

目录 SpringMVC 获取连接 RequestMapping / GetMapping... 获取参数 获取querystring中的参数(获取表单数据基本相同) 获取URL中的参数 获取JSON对象 获取文件(通过表单) 获取Cookie 获取Header 获取Session 返回数据 返回数据 返回JSON对象 返回静态页面 请求…

云渲染时可以关机吗_云渲染电脑可以关闭吗?

云渲染可简单理解为放在云端的渲染农场&#xff0c;可区别于用户本地自己搭建的小型私有农场&#xff0c;用户只需将自己制作好的项目文件进行打包&#xff0c;通过 云渲染平台提供的客户端或网页端将文件上传到云端进行渲染。很多用户通过云渲染作业&#xff0c;解放了自己本地…

深耕5G+AIoT产业赛道,2023高通&美格智能物联网技术开放日隆重举行

5月11日&#xff0c;高通技术公司携手美格智能联合举办了“高通&美格智能物联网技术开放日”深圳站活动。大会现场&#xff0c;智能物联网行业合作伙伴齐聚一堂&#xff0c;围绕5GAIoT前沿技术&#xff0c;通过大咖专业的技术分享、落地应用介绍和现场丰富的产品展示&#…

Pytorch nn.Softmax(dim=?) 详解

本文参考自&#xff1a;Pytorch nn.Softmax(dim?) - 知乎 原文写得很好了&#xff0c;我这边另外完善了一些细节&#xff0c;让大家理解地更加直白一些。 可以先去看上面的参考文章&#xff0c;也可以直接看我这篇。 目录 1、tensor1 1&#xff09;已知该矩阵的维度为&am…

vue实现聊天框自动滚动

需求 1、聊天数据实时更新渲染到页面 2、页面高度随聊天数据增加而增加 3、竖向滚动 4、当用户输入聊天内容或者接口返回聊天内容渲染在页面后&#xff0c;自动滚动到底部 5、提供点击事件操控滚动条上下翻动 环境依赖 vue&#xff1a;vue…

两小时搭建属于自己的chatGPT(ChatGLM)免硬件(白嫖)

目录 准备&#xff08;注册&#xff09;: 搭建: API模式: 测试&#xff1a; 总结&#xff1a; 准备&#xff08;注册&#xff09;: 注册modelscope(白嫖)免费使用服务器 https://modelscope.cn/ 按照图片里的选择(选择其他好像不能创建成功) 可以白嫖60多个小时的配置 8…

Java 8 Time 关于java.time包中你可能不知道的使用细节

目录 前言一、时区与时间1. 世界标准时&#xff1a;UTC、GMT、UT2. 地区时&#xff1a;Asia/Shanghai、UTC83. 时区&#xff1a;ZoneId、TimeZone4. 时间偏移量&#xff1a;ZoneOffset5. 时区简称&#xff1a;CTT、PRC 二、主要时间类1. 重要时间接口&#xff1a;Temporal2. 时…

【CocosCreator入门】CocosCreator组件 | Collider(碰撞)组件

Cocos Creator是一款流行的游戏开发引擎&#xff0c;具有丰富的组件和工具&#xff0c;其中碰撞系统组件是该引擎的重要组成部分。该组件可用于检测游戏中各个元素之间的碰撞&#xff0c;例如玩家角色与敌人、子弹与障碍物等。 目录 一、组件介绍 二、组件属性 2.1BoxCollid…

基于SpringBoot+微信小程序的农产品销售平台

基于SpringBoot微信小程序的农产品销售平台 ✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目…

Test Doubles测试替身: Testing in Distributed Systems and Real World

什么是Test Doubles In software testing, we developed unit tests and integration tests to test the codes functionality. However, in the real world, it is very common for a piece of code to interact with external components, for example, databases, public A…

【人工智能概论】pyplot作图中文显示、逐点坐标显示、保存图像

【人工智能概论】pyplot作图中文显示、逐点标记、保存图像 文章目录 【人工智能概论】pyplot作图中文显示、逐点标记、保存图像一. 简单的绘图二. 逐点坐标显示三. 中文显示四. 中文显示可能遇到的问题——缺少字体4.1 下载 SimHei.ttf4.2 复制 SimHei.ttf 到 Matplotlib 的 fo…

好的Robots.txt设计对Google收录有很大的帮助

Robots.txt 文件是用于指导搜索引擎爬虫在网站上爬行的标准。正确地设计 Robots.txt 文件可以帮助 Google 爬虫更好地理解您的网站结构&#xff0c;从而提高您的网站在 Google 搜索引擎上的收录率。 以下是一些设计 Robots.txt 文件的技巧&#xff0c;可以帮助 Google 爬虫更好…

security 报错:There is no PasswordEncoder mapped for the id “null“

security在登录的时候 无法登录成功 首先解读错误 下面百度翻译 安全框架设置了登录验证 说你没有密码编辑器 解决方法 一: 往容器中注册一个PasswordEncoder 解决方法二: 设置用户权限和角色的时候添加方法,加进去一个PasswordEncoder 只需要解决方案的话 下面的内容…

K8S系列之污点和容忍度详细分析

架构图 本篇文档主要介绍污点和容忍度的关系。 污点和容忍度 污点顾名思义就是脏的东西&#xff0c;给节点添加污点来限制pod调度到该节点上&#xff0c;如果pod可以容忍这种污点就可以被调度到有污点的节点上&#xff0c;如果不能容忍就不能被调度到该节点上。 污点作用于节…

排队领奖模式吸引新消费者,电商平台如何创新引流拓客?

在当前的电商市场中&#xff0c;由于竞争日趋激烈&#xff0c;很多电商平台产生了引流拓客缺乏新意的难题&#xff0c;即很难找到新的流量&#xff0c;并且难以把这些流量转化为消费者。在这个瞬息万变的时代&#xff0c;当然是谁有创意谁能吸引消费者&#xff0c;谁才能当道。…

Sequence-to-Sequence Knowledge Graph Completion and Question Answering

[2203.10321] Sequence-to-Sequence Knowledge Graph Completion and Question Answering (arxiv.org) 目录 1 Abstract 2 Introduction 3 KGT5 Model 3.1 Textual Representations & Verbalization 3.2 Training KGT5 for Link Prediction 3.3 Link Prediction Inf…

Inception Network

文章目录 一、Inception Network简介二、CNN的痛点三、Inception Network1. 1x1卷积核1.1 升维/降维&#xff1a;1.2. 调节参数数量&#xff1a;1.3. 增加非线性特性&#xff1a; 2. Inception原始模型3. Inception Module4. Inception Network 四、代码示例 一、Inception Net…

接口自动化测试 vs. UI自动化测试:为什么前者更快,更省力,更稳定?

从入门到精通&#xff01;企业级接口自动化测试实战&#xff0c;详细教学&#xff01;&#xff08;自学必备视频&#xff09; 目录 前言&#xff1a; 一、什么是接口自动化测试和 UI 自动化测试 二、为什么接口自动化测试效率比 UI 自动化测试高 1.执行速度 2.维护成本 3.…

AI人工智能与机器人的探索和应用1.1

文章来源于&#xff1a;https://mp.weixin.qq.com/s/fqivYVdakVKG-zDVfD4Qzg 研究机器人和人工智能的技术已有多年了&#xff0c;想来想去&#xff0c;觉得还是有必要对过往的技术做一些凝练和总结。在此过程中&#xff0c;除了能够将知识系统化&#xff0c;构建自己的知识体系…

三次输错密码后,系统是怎么做到不让我继续尝试的?

故事背景 忘记密码这件事&#xff0c;相信绝大多数人都遇到过&#xff0c;输一次错一次&#xff0c;错到几次以上&#xff0c;就不允许你继续尝试了。 但当你尝试重置密码&#xff0c;又发现新密码不能和原密码重复&#xff1a; 相信此刻心情只能用一张图形容&#xff1a; 虽…