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

STL专项:queue 队列

queue

queue提供了先进先出(First In First Out)的数据结构。队列在尾部添加元素,在头部删除元素。

常见的应用有:模拟、约瑟夫环、bfs、分支限界搜索、单调队列等算法。

创建队列

queue<int> q;//创建一个 int 类型的队列

入队(添加元素)

//使用 push() 函数将元素添加到队列的尾部。

q.push(10)//将10添加到队列尾部

q.push(20)

q.push(30)

出队(删除元素)

//使用 pop() 函数删除队列的头部元素

q.pop();//删除头部元素,即10

访问队列头部元素

//使用 front() 函数获取队列头部元素的引用

int frontElement = q.front();// frontElement 现在是20

访问队列尾部元素

//使用 back() 函数获取队列尾部元素的引用

int backElement = q.back();// backElement 现在是30

检查队列是否为空/获取队列大小

//使用 empty() 函数检查队列是否为空

if(q.empty())//队列为空

if(q.size())//队列不为空

手写队列

//queue和stack一样不允许遍历

int q[N];

int qh=1,qt=0;//qh队头,qt队尾

//入队

q[++qt]=x;

//出队

qh++;

//大小

qt-qh+1

约瑟夫环

约瑟夫环(easy) | 星码StarryCoding 算法竞赛新手村

代码

#include<bits/stdc++.h> using namespace std; void solve(){ int n,m;cin>>n>>m; queue<int> q; for(int i=1;i<=n;i++){ int x;cin>>x; q.push(x); } for(int i=1;i<n;i++){ for(int j=1;j<m;j++){ int x=q.front(); q.pop(); q.push(x); } q.pop(); } cout<<q.front()<<'\n'; } int main(){ int _;cin>>_; while(_--) solve(); return 0; }

区别对待

区别对待 | 星码StarryCoding 算法竞赛新手村

代码

#include<bits/stdc++.h> using namespace std; const int N = 1e5+9; void solve(){ char s[N];cin>>s+1; int n=strlen(s+1); queue<char> q1,q2; for(int i=1;i<=n;i++){ if(s[i]>='0'&&s[i]<='9') q1.push(s[i]); else q2.push(s[i]); } while(q1.size()){ cout<<q1.front(); q1.pop(); } cout<<'#'; while(q2.size()){ cout<<q2.front(); q2.pop(); } cout<<endl; } int main(){ int _;cin>>_; while(_--) solve(); return 0; }
http://www.zskr.cn/news/170594.html

相关文章:

  • YOLO与Linkerd服务网格集成:轻量级通信治理方案
  • STL专项:deque 双端队列
  • STL专项:priority_queue 优先队列(堆)
  • YOLO模型冷启动DNS预解析:减少网络首次延迟
  • EMC的三大法宝②:接地(二)
  • YOLO目标检测全流程拆解:数据标注到GPU部署的每一步
  • 全国首批10城菁彩Vivid影厅启幕,《山河故人》重映见证影像新纪元
  • Linux 入门必掌握的十大命令
  • YOLO与Prometheus Thanos Ruler集成:跨集群告警规则
  • YOLO与Kubeflow MLOps集成:端到端机器学习 pipeline
  • 推荐阅读:深入解析C语言编程中的指针与内存管理
  • 事件委托(Event Delegation)
  • YOLO模型缓存一致性维护:主从同步与失效传播
  • 采样率、信号频谱/频谱混叠原理与matlab仿真分析
  • 构建LLM支持的AI Agent创新思维系统
  • 刻意练习 2.0:如何利用 AI 结对编程实现从“熟练工“到“大师“的进阶?
  • PHP反序列化
  • 年终复盘2.0:NLP自动萃取经验教训,构建可执行策略库
  • 推荐阅读:C语言中的指针与内存管理:构建高效系统的基石
  • YOLO模型冷启动JIT预热:触发热点代码编译机制
  • CF 做题记录(12月)
  • STUN协议:NAT穿透的核心技术与应用实践
  • InfiniBand 网络管理探秘:子网管理器如何发现硬件并分配网络地址
  • GEO贴牌代理赋能AI搜索推荐,让品牌在智能问答中优先展现 - 源码云科技
  • SDP协议:实时通信的会话描述基石
  • YOLO模型灰度发布完成后正式版替换流程
  • 母子定律,准到吓人
  • YOLO与Spinnaker部署平台集成:多环境渐进式发布
  • YOLO模型训练任务依赖管理:有向无环图调度实现
  • 在微网的世界里,电能共享是个大话题。今天咱们聊聊如何用非对称纳什谈判来优化多微网间的电能共享,顺便加点代码,让大家感受一下这个高级玩意儿