模板题练习

news/2025/3/3 20:27:27/文章来源:https://www.cnblogs.com/Easoncalm/p/18749163

栈(Stack) 队列 (Queue)

题目:B3614

题目:B3616

直接调用 C++ STL函数库里面的 stackqueue ,分别代表栈和队列。

Stack

  • push : 将一个压入栈顶,形如y.push(x)

  • pop :将一个元素弹出栈,当且仅当栈非空的情况下,形如y.pop()

  • empty : 返回当前这个栈是否为空,形如y.empty()

  • top : 返回栈顶元素(不弹出),当且仅当栈非空的情况下,形如y.top()

  • size : 返回当前栈的元素数量,形如y.size()

Queue

  • push : 将一个加入队列,形如y.push(x)

  • pop :将一个元素弹出队列,当且仅当队列非空的情况下,形如y.pop()

  • empty : 返回当前这个栈队列是否为空,形如y.empty()

  • front : 返回队首元素(不弹出),当且仅当队列非空的情况下,形如y.top()

  • size : 返回当前队列的元素数量,形如y.size()

分别对应的代码如下:

#include <bits/stdc++.h>
#define ull unsigned long long
using namespace std;main() {cin.tie(0);ios::sync_with_stdio(false);ull t;cin >> t;while (t--) {ull n;cin >> n;stack<ull> st;while (n--) {string s;cin >> s;if (s == "push") {ull k;cin >> k;st.push(k);} else if (s == "pop") {if (st.empty())cout << "Empty\n";else {st.pop();}} else if (s == "query") {if (st.empty())cout << "Anguei!\n";else {cout << st.top() << endl;}} else if (s == "size") {cout << st.size() << endl;}}}return 0;
}
#include <bits/stdc++.h>
using namespace std;int main() {queue<int> q;int t;cin >> t;while (t--) {int n;cin >> n;if (n == 1) {int m;cin >> m;q.push(m);}if (n == 2) {if (q.empty())cout << "ERR_CANNOT_POP\n";elseq.pop();}if (n == 3) {if (q.empty())cout << "ERR_CANNOT_QUERY\n";elsecout << q.front() << "\n";}if (n == 4) {cout << q.size() << endl;}}return 0;
}

链表(List)

题目:B3631

与上两个不同,c++里面没有专门为链表设计STL,所以我们自己用struct设计。

首先在定义的时候,先考虑我们应该设计什么变量。

第一,需要当前元素的值对吧。第二,需要下一个元素的位置(也就是地址)对吧。由此可得:

struct Node{int val;Node next;//这里使用Node来作属性,主要是因为我们需要的是地址//所以我们不能用其它属性,类似一个重复递归(bushi)。
};

现在根据题意设计函数:

  • 链接函数:x的next相等于y的next,y的next等于y的值。

  • 删除函数:直接向简单点,把我们需要删除元素的上一个元素的指向直接指向这个元素的下一个元素,即可完成删除,不需要对这个元素做其他的处理,这就是相较于数组,可以做到O(1)的好处。

  • 添加函数:显而易见,直接在末尾函数的下一个就是我们需要的值。

由此可得代码:

#include <bits/stdc++.h>
using namespace std;struct Node {int value;Node *next;Node(int v) : value(v), next(NULL) {}
};Node *li[1000001] = {NULL};int main() {int q;cin >> q;li[1] = new Node(1);li[1]->next = NULL;while (q--) {int op;cin >> op;if (op == 1) {int x, y;cin >> x >> y;Node *xn = li[x];Node *yn = new Node(y);yn->next = xn->next;xn->next = yn;li[y] = yn;} else if (op == 2) {int x;cin >> x;Node *xn = li[x];cout << ((xn->next) ? xn->next->value : 0) << endl;} else if (op == 3) {int x;cin >> x;Node *xn = li[x];if (xn->next) {Node *yn = xn->next;xn->next = yn->next;li[yn->value] = NULL;delete yn;}}}return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

修理牛棚

思路: 有的牛棚住牛,有的是空的,从反过来的思路来想,先用一块木板盖住所有有猪住的猪棚,减去空牛棚数,最终得到最多被木板挡住门的牛棚的数量。 代码展示: #include<bits/stdc++.h> using namespace std; const int N=210; int m,s,c;int a[N],b[N];int main() {c…

写了个 CasaOS/ZimaOS 内网穿透的远程访问插件(不是 frp 或者 nps),欢迎大家测试使用

插件正在提交,应该过几天就会进入市场了。 插件访问效果大概如下: casaOS 远程界面 如果大家想先行测试可以手动下载 pr 的文件进行测试。使用 插件会提供一个二维码,使用OpenIoThub 开源 APP扫码添加插件网关,然后在客户端上添加要访问的主机,然后在主机下面添加端口,然…

20241904 2024-2025-2 《网络攻防实践》第一周作业

​ 一、知识点梳理与总结 1、 实验介绍 1) VM操作系统的三种网络连接方式的适用情况 (1)桥接(Bridged)模式 桥接模式就是将主机网卡与虚拟机虚拟的网卡利用虚拟网桥进行通信。在桥接的作用下,类似于把物理主机虚拟为一个交换机,所有桥接设置的虚拟机连接到这个交换机的一…

从cURL到GraphQL:不同API类型概述

从cURL到GraphQL:不同API类型概述 API(应用程序编程接口)是现代软件开发的支柱,能够使不同的应用程序进行通信、共享数据并无缝执行任务。了解各种API类型及其实际应用可以为开发人员提供宝贵的见解。本文将探讨不同的API类型、它们的重要性,并通过实际示例说明它们的应用…

【H2O】--【HybrIK】关于RGB2SMPL算法工程HybrIK的安装记录

1. 前言 主要记录关于RGB2SMPL算法工程HybrIK的安装记录。 一方面便于日后自己的温故学习,另一方面也便于大家的学习和交流。 如有不对之处,欢迎评论区指出错误,你我共同进步学习! 2. 正文 2.0 torch_tricks model.train()的作用是启用 Batch Normalization 和 Dropout。 m…

粤港澳大湾区-工业软件中心-诚聘CAE测试专家、高性能计算专家、系统工程师、CAE软件架构师、嵌入式软件开发工程师、数据库软件测试工程师等(广州 不限制年龄)

简介 粤港澳大湾区国家技术创新中心工业软件产业发展中心,是粤港澳大湾区国家技术创新中心直属创新平台之一。该中心致力于聚焦工业软件基础创新,构建工业软件全过程创新生态链,为推动我国工业软件产业发展做出重要贡献。 主要目标攻克核心技术: 突破工业软件核心关键技术,…

09 深度神经网络框架的基础:自动微分

当神经网络的层数增加,结构变复杂后,如果只用纯python(再加Numpy)来实现,代码将变得异常复杂,且难以阅读和调试。此时,就需要引入一些著名的深度学习框架了,比如PyTorch, TensorFlow等。 运用这些框架,你往往只需要定义一个神经网络的架构,反向传播过程则是自动完成的…

WebSocket调试工具深度对比:Postman与Apipost功能实测解析

WebSocket调试工具深度对比:Postman与Apipost功能实测解析 作为长期从事实时通讯系统开发的工程师,WebSocket协议在开发中是非常常见的。作为一种常见的 Web 协议,其与 Restful API 有着本质的不同。Restful API是基于请求-响应模式的单向通信,而 WebSocket 提供全双工通信…

leetcode hot 18

解题思路:这题思路就是用某个数据结构记录需要被置0的行和列,一般需要两次遍历。我采用集合的形式,最省空间的方法就是用数组的第一行和第一列来记录,但是要遍历一遍是是否第一行或第一列有0。 class Solution {public void setZeroes(int[][] matrix) {Set<Integer> …

中国版Workday从上千家大型跨国企业的实践总结:员工体验很重要

20世纪90年代中期,从Oracle、SAP等国外ERP巨头进入中国,并拿下华为、联想等一流企业,至今也依然保持着中国市场的优势地位。即便到了“国外企业应用软件在中国逐步式微”的今天,SAP约10000亿元的市值,也远超用友的约1000亿元市值。其中很大一个原因在于,中国企业的聪明—…

易路iBuilder—国内首个HR智能体管理平台,高效管理企业数字劳动力

易路iBuilder智能体平台不仅是工具集合,更是企业数字化转型的 “智能中枢”。它通过知识驱动、流程重构、人机共融,帮助企业将AI Agent从“执行者”升级为“战略伙伴”,最终实现 “人类定义价值,机器放大价值”的新工作范式。随着大模型技术的商业应用日益成熟,AI数字员工…