当前位置: 首页 > news >正文

用数组模拟栈和队列

先进后出

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

//stk 表示定义的栈
//tt表示栈顶的下标
int stk[N], tt = 0;//在栈顶上加入一个新的元素
stk[++ tt] = x;//弹出
tt --;//判断栈是否为空
if (tt > 0) 不为空
else empty//取出栈顶
stk[tt];
1.题目

给定一个长度为 N 的整数数列,输出每个数左边第一个比它小的数,如果不存在则输出 − 1。

输入格式

第一行包含整数 N ,表示数列长度。

第二行包含 N 个整数,表示整数数列。

输出格式

共一行,包含 N 个整数,其中第 i 个数表示第 i 个数的左边第一个比它小的数,如果不存在则输出 − 1 。

数据范围

1≤N≤10^5

1≤数列中元素≤10^9

所有操作保证合法。 所有操作保证合法。所有操作保证合法。

输入样例:

5
3 4 2 7 5

输出样例:

-1 3 -1 2 2

也就是说栈里面的数 不能大于新插入的元素

#include <iostream>using namespace std;
const int N = 100010;
int stk[N], tt = 0;int main()
{int n;cin >> n;for (int i = 0; i < n; i++){int x;cin >> x;while (tt != 0 && stk[tt] >= x) tt--;if ( tt ) cout << stk[tt] << " ";else cout << " -1 " << " ";stk[++tt] = x;}return 0;
}

队列

先进先出:队尾插入元素,队头弹出元素

在这里插入图片描述

1、普通队列

// q[] 表示队列
// hh 表示队头,tt表示队尾
int q[N], hh = 0, tt = -1;// 向队尾插入一个数
q[ ++ tt] = x;//弹出
hh ++;//判断队列是否为空
if (hh <= tt) 不为空
else 为空//取出队头元素
q[hh];
http://www.lryc.cn/news/420077.html

相关文章:

  • Django内置后端和自定义后端
  • 嵌入式人工智能(OpenCV-基于树莓派的人脸识别与入侵检测)
  • 如何选择适合的香港云服务器提供商?
  • 安卓Android JAVA校招/实习面试合集:多线程、强软弱虚引用、进程、内存管理、Activity、Fragment......
  • Jeecgboot 字典值自动转化:DictAspect类方法改造,支持IPage、List、Object、Map类自动转化,附有源码
  • DVWA DOM Based Cross Site Scripting (DOM型 XSS)
  • LinkedList集合及迭代器的源码分析
  • Go调度器
  • 当node节点kubectl 命令无法连接到 Kubernetes API 服务器
  • 直接通过类CURL方式,与GRPC方法交互的命令行工具
  • Hive3:数据的加载与导出
  • React事件绑定的方式有哪些?区别?
  • ibis:极具潜力的Python数据分析新框架
  • SQL Zoo 8+.NSS Tutorial
  • conda pack迁移环境
  • UML建模案例分析-活动图商业建模
  • C++标准模板(STL)- 低层内存管理 - 解分配函数 (operator delete, operator delete[])
  • LeetCode 热题 HOT 100 (025/100)【宇宙最简单版】
  • 【mysql 第三篇章】一条 update语句是怎么持久化到磁盘上的?
  • 深入探索大模型:从基础到实践,开启AI之旅
  • 题解:力扣1567 - 返回乘积为正数的最长子数组
  • 009 | 上证50ETF基金数据分析及预测
  • Wakanda: 1靶场复现【附代码】(权限提升)
  • 内核函数调试
  • Spring IOC使用DButil实现对数据库的操作
  • Android14音频进阶调试之命令播放mp3/aac非裸流音频(八十)
  • vue中怎么自定义组件
  • BM1反转链表[栈+头插法]
  • VisionPro二次开发学习笔记10-使用 PMAlign和Fixture固定Blob工具检测孔
  • 学单片机怎么在3-5个月内找到工作?