news 2026/4/18 1:18:12

寒假集训2——队列

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
寒假集训2——队列

1.P1996 约瑟夫问题

题目描述

n 个人围成一圈,从第一个人开始报数,数到 m 的人出列,再由下一个人重新从 1 开始报数,数到 m 的人再出圈,依次类推,直到所有的人都出圈,请输出依次出圈人的编号。

注意:本题和《深入浅出-基础篇》上例题的表述稍有不同。书上表述是给出淘汰 n−1 名小朋友,而该题是全部出圈。

输入格式

输入两个整数 n,m。

输出格式

输出一行 n 个整数,按顺序输出每个出圈人的编号。

输入输出样例

输入 #1复制

10 3

输出 #1复制

3 6 9 2 7 1 8 5 10 4

说明/提示

1≤m,n≤100

#include<iostream> #include<queue> using namespace std; int n,m; int main() { queue <int>q; cin>>n>>m; for(int i=1;i<=n;i++) q.push(i); while(q.size()) { //把队头移到队尾 //类似循环队列 //注意是移动m-1次,不是m次 for(int j=1;j<m;j++) { int mov=q.front(); q.pop(); q.push(mov); } //淘汰队头 cout<<q.front()<<" "; q.pop(); } return 0; }

2.B3616 【模板】队列

题目描述

请你实现一个队列(queue),支持如下操作:

  • push(x):向队列中加入一个数 x。
  • pop():将队首弹出。如果此时队列为空,则不进行弹出操作,并输出ERR_CANNOT_POP
  • query():输出队首元素。如果此时队列为空,则输出ERR_CANNOT_QUERY
  • size():输出此时队列内元素个数。

输入格式

第一行,一个整数 n,表示操作的次数。

接下来 n 行,每行表示一个操作。格式如下:

  • 1 x,表示将元素x加入队列。
  • 2,表示将队首弹出队列。
  • 3,表示查询队首。
  • 4,表示查询队列内元素个数。

输出格式

输出若干行,对于每个操作,按「题目描述」输出结果。

每条输出之间应当用空行隔开。

输入输出样例

输入 #1复制

13 1 2 3 4 1 233 3 2 3 2 4 3 2 1 144 3

输出 #1复制

2 1 2 233 0 ERR_CANNOT_QUERY ERR_CANNOT_POP 144

说明/提示

样例解释

首先插入2,队首为2、队列内元素个数为1
插入233,此时队首为2
弹出队首,此时队首为233
弹出队首,此时队首为空。
再次尝试弹出队首,由于队列已经为空,此时无法弹出。
插入144,此时队首为144

数据规模与约定

对于 100% 的测试数据,满足 n≤10000,且被插入队列的所有元素值是 [1,1000000] 以内的正整数。

#include<iostream> using namespace std; const int N=1e5+10; int q[N]; int front,back,size; void Push(int x) { back++; q[back]=x; } int Size() { return back-front; } void Pop() { if(Size()>0) front++; else cout<<"ERR_CANNOT_POP"<<endl; } void Query() { if(Size()>0) cout<<q[front+1]<<endl; else cout<<"ERR_CANNOT_QUERY"<<endl; } int main() { int n; cin>>n; int input=0; while(n--) { cin>>input; if(input==1) { int x; cin>>x; Push(x); } else if(input==2) Pop(); else if(input==3) Query(); else if(input==4) cout<<Size()<<endl; } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 2:17:27

不同场景使用不同进制表示的庖丁解牛

“不同场景使用不同进制表示” 是计算机系统为 平衡人类可读性与机器效率 而设计的分层抽象策略。它不是随意选择&#xff0c;而是 在特定上下文中&#xff0c;某种进制能最高效地传递信息、减少错误、提升性能。一、核心原理&#xff1a;进制是信息的“压缩格式”进制基数信息…

作者头像 李华
网站建设 2026/4/16 16:01:11

CI/CD中的测试环境清理:实现跑完自动销毁

测试环境清理的紧迫性与价值在现代CI/CD流水线中&#xff0c;测试环境的自动化管理已成为提升软件交付效率的核心环节。测试完成后自动销毁环境&#xff0c;不仅能避免资源浪费和配置残留&#xff0c;还能确保每次测试都在干净、一致的状态下运行&#xff0c;减少“环境漂移”问…

作者头像 李华
网站建设 2026/4/12 8:27:39

国内iPaas平台推荐

国产iPaaS顶流&#xff01;连趣云凭什么成为制造零售企业的集成首选&#xff1f; 当企业数字化进入深水区&#xff0c;ERP、MES、CRM等系统不再是孤立的工具&#xff0c;而是需要协同作战的“数字军团”。但系统林立、数据孤岛、集成成本高企等问题&#xff0c;却成为制造与零…

作者头像 李华
网站建设 2026/4/9 20:22:33

数据分析师的Python工具箱

SQLAlchemy是Python中最流行的ORM&#xff08;对象关系映射&#xff09;框架之一&#xff0c;它提供了高效且灵活的数据库操作方式。本文将介绍如何使用SQLAlchemy ORM进行数据库操作。目录安装SQLAlchemy核心概念连接数据库定义数据模型创建数据库表基本CRUD操作查询数据关系操…

作者头像 李华
网站建设 2026/4/17 18:50:32

C++代码复杂度控制

1、非修改序列算法这些算法不会改变它们所操作的容器中的元素。1.1 find 和 find_iffind(begin, end, value)&#xff1a;查找第一个等于 value 的元素&#xff0c;返回迭代器&#xff08;未找到返回 end&#xff09;。find_if(begin, end, predicate)&#xff1a;查找第一个满…

作者头像 李华
网站建设 2026/4/16 15:24:22

Thinkphp和Laravel网红酒店预定系统的设计与实现_ui9bt

目录 Thinkphp和Laravel框架的选择系统功能模块设计数据库设计技术实现细节性能优化与安全用户体验与界面设计测试与部署总结 项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理 Thinkphp和Laravel框架的选择 Thinkphp和Laravel均为流行的PHP框架&a…

作者头像 李华