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

基础数据结构:栈、队列、链表

文章目录

    • 核心操作
    • 练习题
  • 队列
    • 核心操作
    • 练习题
  • 链表
    • 核心操作

先进后出

栈是一种限制访问端点的线性表,它只允许在表的一端进行插入和删除操作。这一端被称为栈顶,另一端称为栈底

就如同一个杯子,杯子的顶端相当于栈顶,底端就相当于是栈底,要想把杯子里面的东西取出来,只能从杯子的上面往外倒

核心操作

push(入栈)、pop(出栈)、top(查看栈顶)、size(栈的大小)、empty(栈是否为空)

C++ STL中的栈

#include<bits/stdc++.h>usingnamespacestd;intmain(){stack<int>s;// 入栈操作s.push(1);s.push(2);s.push(3);cout<<"栈大小: "<<s.size()<<endl;// 3cout<<"栈顶元素: "<<s.top()<<endl;// 3// 出栈操作s.pop();cout<<"弹出后栈顶: "<<s.top()<<endl;// 2// 遍历栈while(!s.empty()){cout<<s.top()<<" ";s.pop();}// 输出: 2 1return0;}

练习题

表达式括号匹配

#include<bits/stdc++.h>usingnamespacestd;intmain(){string s;cin>>s;intcnt1=0,cnt2=0;for(inti=0;i<s.size();i++){if(s[i]=='(')cnt1++;if(s[i]==')')cnt2++;}if(cnt1!=cnt2){cout<<"NO"<<endl;return0;}stack<char>stk;for(inti=0;i<s.size();i++){if(s[i]==')'){boolf=0;while(!stk.empty()){charc=stk.top();if(c=='('){f=1;stk.pop();break;}else{stk.pop();}}if(f!=1){cout<<"NO"<<endl;return0;}}else{stk.push(s[i]);}}cout<<"YES"<<endl;return0;}

队列

先进先出

队列是一种限制访问端点的线性表,它只允许在表的一端进行插入(队尾),在另一端进行删除(队首)

就像是排队买东西,在没有插队的情况下,你只能从后面开始排,然后从最前面离开

核心操作

push(入队)、pop(出队)、front(查看队首)、size(队列大小)、empty(队列是否为空)

C++ STL中的队列

#include<bits/stdc++.h>usingnamespacestd;intmain(){queue<int>q;// 入队操作q.push(1);q.push(2);q.push(3);cout<<"队头元素: "<<q.front()<<endl;// 1cout<<"队列大小: "<<q.size()<<endl;// 3// 出队操作q.pop();cout<<"出队后队头: "<<q.front()<<endl;// 2// 遍历队列while(!q.empty()){cout<<q.front()<<" ";q.pop();}// 输出: 2 3return0;}

练习题

【模板】队列

#include<bits/stdc++.h>usingnamespacestd;intmain(){ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);intn;cin>>n;queue<int>q;while(n--){intt;cin>>t;if(t==1){intx;cin>>x;q.push(x);}elseif(t==2){if(q.empty()){cout<<"ERR_CANNOT_POP"<<'\n';}else{q.pop();}}elseif(t==3){if(q.empty())cout<<"ERR_CANNOT_QUERY"<<'\n';elsecout<<q.front()<<'\n';}elseif(t==4){cout<<q.size()<<'\n';}}return0;}

链表

链表(Linked List)是一种线性数据结构,它由一系列节点(Node)组成。与数组不同的是,链表中的元素在内存中不是连续存储的,而是通过指针连接在一起。

🚂 火车车厢的比喻

想象一列火车🚂,每节车厢就是一个节点:

  • 车厢本身:装载货物(数据)
  • 车厢挂钩:连接下一节车厢(指针)
  • 车头:第一节车厢(头指针 HEAD)

可以随时加挂或卸下车厢(插入/删除),但要找到第5节车厢,必须从车头开始一节一节数过去。

链表节点的结构

每个链表节点包含两个关键部分:

┌─────────────┬─────────────┐ │ 数据域 │ 指针域 │ │ Data │ Next → │ └─────────────┴─────────────┘

举个例子:

HEAD(头指针) ↓ ┌────┬──┐ ┌────┬──┐ ┌────┬──┐ │ 10 │→ │ → │ 20 │→ │ → │ 30 │∅ │ └────┴──┘ └────┴──┘ └────┴──┘ 节点1 节点2 节点3(尾)

代码中的定义是:

// 链表节点定义structNode{intdata;// 数据域:存储实际数据Node*next;// 指针域:指向下一个节点};

核心操作

插入节点

在头部插入节点

voidinsertAtHead(intval){Node*newNode=newNode(val);// 创建新节点newNode->next=head;// 新节点指向原头节点head=newNode;// 更新头指针}

在尾部插入节点

voidinsertAtTail(intval){Node*newNode=newNode(val);if(head==nullptr){// 如果链表为空head=newNode;return;}Node*temp=head;while(temp->next!=nullptr){// 遍历到最后一个节点temp=temp->next;}temp->next=newNode;// 连接新节点}
http://www.jsqmd.com/news/73370/

相关文章:

  • Docker + 多模态Agent = 王炸组合?5个真实生产环境编排案例深度剖析
  • Windows上解决test.c LINK : fatal error LNK1181: 无法打开输入文件“aio.lib” 无法打开输入文件“cufile.lib”
  • 第十一章篇 实现拦截器
  • 揭秘MCP PL-600多模态Agent设计:如何实现跨模态协同与自主决策
  • 从零构建智能Agent编排系统,掌握Docker Swarm与K8s协同秘技
  • Docker Buildx构建缓慢?你必须知道的7个Agent镜像优化实践
  • Linux新手必学:tail命令图解指南
  • 8 个自考论文降重工具,AI 免费网站推荐
  • 如何为你的Python项目构建pyproject.toml文件
  • 新手鱼竿推荐:新手买钓鱼竿怎么选?2025年鱼竿新手入门推荐 - 品牌2026
  • C++ ⼀级 2023 年06 ⽉
  • NPI(New Product Introduction)工程师职责介绍
  • 卡内基跨学科团队利用随机森林模型,基于406份样本成功捕捉33亿年前生命遗迹
  • 【STM32】低功耗
  • 基于 ESP32 的对话机器人实现:整合 Coze 大模型、百度千帆 ASR 与 TTS
  • Spark 运行架构及相关概念
  • 基于SpringBoot的学生评奖评优管理系统-计算机毕业设计源码+LW文档分享
  • MySQL 主从同步与读写分离详解
  • 2025年鱼竿排列前十的品牌:山东威海鱼竿生产厂家精选解析 - 品牌2026
  • 护网行动关键方向深度分享:应急响应 / 云原生防护等五大领域文章 + 实战技巧,附案例拆解!
  • 基于SpringBoot的学生学习成果展示平台的实现-计算机毕业设计源码+LW文档分享
  • 【稀缺资源】全球仅5%团队掌握的供应链量子优化代码模板(Python版)
  • 98465
  • http协议中各个网段含义
  • MagicTime: Time-Lapse Video Generation Models asMetamorphic Simulators论文精读(1)
  • 你用过哪些国产实时数据库?
  • ISO20000新版标准深度解析:5大关键变化如何重塑IT服务管理
  • OpenHarmony Flutter 分布式安全与隐私保护:跨设备可信交互与数据防泄漏方案
  • 计算机Java毕设实战-基于springboot高校大学生心理咨询管理系统springboot大学生心理健康分析及干预平台【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • C++设计模式大乱斗:让代码不再“乱炖”(一)