zg584_O-Z39663

zg584_O-Z396631396:队列问题(2)TimeLimit: 1Sec  MemoryLimit: 128MB[Submit][Status][WebBoard]Description有一个含有n个元素的队列q,每个元素的大小满足1Input输入数据第一行是一个整数T(1Output对于每组测试数据,输出xm是第几个出队列。S

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

1396: 队列问题(2)

Time Limit: 1 Sec  
Memory Limit: 128 MB

[
Submit][
Status][
Web Board]

Description

有一个含有n个元素的队列q,每个元素的大小满足1<=xi<=9(0<i<n)。队列有一种操作,对于队首元素若是整个队列最大的则出队列,否则加入队尾。对于一个给定的m,你能告诉我xm是第几个出队列的吗?

Input

输入数据第一行是一个整数T(1<=T<=1000),表示输入数据的组数;每组数据的第一行是两正整数n表示队列的大小和第几个元素(1<n<=1000,0<=m<n),第二行有n个数xi ,分别代表每个元素的大小。

Output

对于每组测试数据,输出xm是第几个出队列。

Sample Inp

3
1 0
5
4 2
1 2 3 4
6 0
1 1 9 1 1 1

Sample Output

1
2
5

【分析】

stl的练习题,multset是不会判重的set,用来记录当前最大值即可,因为set本身是升序,所以需要重载比较命令greater<int>
然后就是按照题目所说的queue直接模拟即可,因为要找到第i个,所以可以在第i个元素后面插入一个-1作为标记,若某一次pop操作之后队首是-1,那么说明第m个元素已经被弹出了,这时候输出答案就可以了
【代码】

#include <cstdio>
#include <iostream>
#include <queue>
#include <set>
using namespace std;

queue<int>a;
multiset<int,greater<int> >b;

int main()
{
	int pp;scanf("%d",&pp);
	while (pp--)
	{
		int n,m;scanf("%d%d",&n,&m);
		while (!a.empty()) a.pop();
		b.clear();
		for (int i=0;i<n;i++)
		{
			int x;scanf("%d",&x);
			a.push(x);
			b.insert(x);
			if (i==m) a.push(-1);
		}
		int ans=0;
		while (1)
		{
			//printf("%d**%d\n",a.front(),*b.begin());
			if (a.front()==*b.begin())
			{
				ans++;
				a.pop();
				b.erase(b.begin());
				if (a.front()==-1) break;
			}
			else
			{
				a.push(a.front());
				a.pop();
			}
		}
		printf("%d\n",ans);
	}	
}
 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169961.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 第一个Java程序—HelloWorld[通俗易懂]

    第一个Java程序—HelloWorld[通俗易懂]工欲善其事必先利其器,在写第一个Java程序之前,需要安装JDK以及配置环境变量,具体步骤见Windows中配置Java环境变量。环境变量搭建完成了,是不是已经迫不及待想敲几行代码跑跑看?走起!1.在英文路径下创建一个记事本文件,命名为HelloWorld.java。这个文件是存放java代码的文件,称为源文件。这里是将文件类型改为java类型,并不单单是名字。这里的.java是文件类型,有的电脑上可能文件后缀名给隐藏了,虽然文件名里有.java但不是个java文件。可以点击查看,将文件扩展

    2022年7月9日
    17
  • qq能够正常登陆但使用域名无法访问internet的解决方法

    qq能够正常登陆但使用域名无法访问internet的解决方法

    2021年9月11日
    119
  • linux修改程序文件内容,linux 批量修改文件内容

    linux修改程序文件内容,linux 批量修改文件内容如果有批量修改文件内容的需求,可参考下面这些方法1.批量查找某个目下文件的包含的内容,例如:#grep-rn或l”要找查找的文本”路径或文件rn表示匹配查找字符串的内容显示出来和行号rl表示匹配查找字符串的文件名全部显示出来比如grep-rn”aaa”/usr/local/表示/use/local目录下所有匹配”aaa”的字符串和行号grep-rl”aaa”…

    2022年7月26日
    10
  • pycharm结果显示窗口_pycharm怎么显示图片

    pycharm结果显示窗口_pycharm怎么显示图片问题描述在电脑中重新安装Anaconda3&PyCharm后,运行原来的程序画图时出现了下图界面。不能弹出如下图所示的“figure”窗口。解决方法:这是因为PyCharm在Sciview中开放它。具体操作步骤如下所示:1、“File—&gt;Settings”,打开Settings窗口。2、找到“PythonScientific”,去除右边候选框中的勾号。…

    2022年8月25日
    6
  • javah 用法_java enum用法

    javah 用法_java enum用法在android 用法:javah[选项]其中[选项]包括:       -help                输出此帮助消息并退出        -classpath    用于装入类的路径        -bootclasspath用于装入引导类的路径        -d            输出目录        -o

    2025年12月10日
    4
  • Linux文本编辑器——vim「建议收藏」

    Linux文本编辑器——vim「建议收藏」Linux文本编辑器edpicoemacsnanogVimvimvivim是文本编辑器不是文字处理工具(officelibofficewps)你的运维生涯99.999999%离不开它rhel(centos)里最小化安装没有vim只有vi,记得装包vim基于perl开发的,所以vim依赖perl环境vim有三种模式分别为:…

    2022年7月26日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号