news 2026/6/10 10:54:43

寒假集训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/6/10 14:56:04

我把测试报告生成为“可分享链接”,一键发给客户

测试报告分享的痛点与变革机遇 在软件开发生命周期中&#xff0c;测试报告是沟通团队与客户的桥梁&#xff0c;它汇总了缺陷、通过率、风险等关键数据&#xff0c;直接影响项目决策和客户信任。然而&#xff0c;传统分享方式——如邮件附件、手动上传云盘——常导致版本混乱、…

作者头像 李华
网站建设 2026/6/10 14:57:02

基于Thinkphp和Laravel的健身房管理系统_bgnk6

目录 基于ThinkPHP和Laravel的健身房管理系统主要功能模块技术实现系统优势 项目开发技术介绍PHP核心代码部分展示系统结论源码获取/同行可拿货,招校园代理 基于ThinkPHP和Laravel的健身房管理系统 该系统是一个结合ThinkPHP和Laravel框架开发的健身房管理平台&#xff0c;旨在…

作者头像 李华
网站建设 2026/6/10 14:52:45

计算机毕设 java 基于 CSS 的罗技购物网站 基于 SpringBoot 的罗技产品电商平台 Java 罗技数码产品购物管理系统

计算机毕设 java 基于 CSS 的罗技购物网站 7763n9&#xff08;配套有源码 程序 mysql 数据库 论文&#xff09;本套源码可以先看具体功能演示视频领取&#xff0c;文末有联系 可分享在电商行业快速发展的背景下&#xff0c;罗技产品的线上销售面临商品展示不直观、订单管理繁琐…

作者头像 李华
网站建设 2026/6/10 10:20:51

用Python读取和处理NASA公开API数据

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

作者头像 李华
网站建设 2026/6/10 2:22:53

usb3 协议

一、 基本概念 低频周期性信令&#xff08;LFPS&#xff0c;Low frequency periodic signaling&#xff09; Low frequency periodic signaling (LFPS) is used for side band communication between the two ports across a link that is in a low power link state. It is al…

作者头像 李华
网站建设 2026/6/9 22:50:37

模板特化与偏特化实战

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

作者头像 李华