HDU4907小技巧

HDU4907小技巧

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

原题http://acm.hdu.edu.cn/showproblem.php?pid=4907

Task schedule

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 692    Accepted Submission(s): 334

Problem Description
有一台机器,而且给你这台机器的工作表,工作表上有n个任务,机器在ti时间运行第i个任务,1秒就可以完毕1个任务。

有m个询问,每一个询问有一个数字q,表示假设在q时间有一个工作表之外的任务请求,请计算何时这个任务才干被运行。

机器总是依照工作表运行,当机器空暇时马上运行工作表之外的任务请求。

 

Input
输入的第一行包括一个整数T, 表示一共同拥有T组測试数据。

对于每组測试数据:

第一行是两个数字n, m,表示工作表里面有n个任务, 有m个询问;

第二行是n个不同的数字t1, t2, t3….tn,表示机器在ti时间运行第i个任务。

接下来m行,每一行有一个数字q,表示在q时间有一个工作表之外的任务请求。

特别提醒:m个询问之间是无关的。

[Technical Specification]

1. T <= 50

2. 1 <= n, m <= 10^5

3. 1 <= ti <= 2*10^5, 1 <= i <= n

4. 1 <= q <= 2*10^5

 

Output
对于每个询问,请计算并输出该任务何时才干被运行,每个询问输出一行。

 

Sample Input
   
   
1 5 5 1 2 3 5 6 1 2 3 4 5

 

Sample Output
   
   
4 4 4 4 7

//本题要是直接做会超时,所以採用预处理的方法。听说二分也能够,只是没有试过,感觉预处理已经挺快的了
//思路,开个数组,代表在i秒进行额外工作的时间。非常明显,在预处理的时候要从后往前找
//假设该时间该机器本身不须要工作,那么就吧时间不断的缩小
include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#include <limits.h>
#include <string.h>
#include <string>
#include <math.h>
#include <algorithm>
#include <iostream>
#include <stack>
#include <queue>
#include <deque>
#include <vector>
#include <set>
#include <map>
using namespace std;
#define N 100000 + 10
#define M 200000 + 10
int vis[M];
int take[M];

int main(){
	int T,n,m;

	while(~scanf("%d",&T)){
		while(T--){
			memset(vis,0,sizeof(vis));
			memset(take,0,sizeof(take));
			scanf("%d%d",&n,&m);
			int i,num;
			for(i=1;i<=n;i++){
				scanf("%d",&num);
				vis[num] = 1;
			}
			int mark;
			for(i=200000;i>=1;i--){
				take[i] = i;
				if(vis[i] == 0){
					mark = i;
				}
				else{
					take[i] = mark;
				}
			}
			int t;
			for(i=1;i<=m;i++){
				scanf("%d",&t);
				printf("%d\n",take[t]);
			}
		}
	}

	return 0;
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

(0)
上一篇 2021年12月2日 上午7:00
下一篇 2021年12月2日 上午7:00


相关推荐

  • Java桌面程序开发——如何开发美观漂亮好看的桌面程序

    Java桌面程序开发——如何开发美观漂亮好看的桌面程序大家想到使用 Java 这门编程语言大多是脑海中是浮现的 B S 开发 高并发 云计算 大数据等等 今天给大家带来的是 Java 不一样的使用方式 使用 Java 做 PC 桌面程序开发 不同的是 之前 Java 是使用 swing 或者 awt 开发 但是这次介绍给大家的是使用 JavaFx 做桌面程序开发 应该没有人使用过电脑版的 酷狗 视频播放器等等软件 它们都有非常漂亮的 UI 也就是界面 可是我们使用 swi

    2026年3月17日
    3
  • log4j使用教程详解(怎么使用log4j2)_log4j配置详解

    log4j使用教程详解(怎么使用log4j2)_log4j配置详解日志是应用软件中不可缺少的部分,Apache的开源项目Log4j是一个功能强大的日志组件,提供方便的日志记录。在apache网站:jakarta.apache.org/log4j可以免费下载到Log4j最新版本的软件包。

    2025年7月29日
    2
  • oracle先排序再分页

    oracle先排序再分页

    2021年6月30日
    150
  • 关于精灵图

    关于精灵图之前就发现一些网站吧所有的小图标拼接在一张图片中,但是一直不知道这是怎么做到的,今天特地了解了一下,才知道这种用法叫做精灵图。他的优点是可以减少浏览器请求的次数,把所有图片拼接在一张图中就只需要请求一次,当浏览器需要用到图片时再从大图片中解析。这样可以加快访问的次数。先来看看效果图:拼接的图片:他的原理是,先规定好每个小图标的大小,创建一个和小图标大小相同的容器,再通过移动背景图片的方法将…

    2022年5月29日
    61
  • 程序世界,平凡的我

    做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!昨天是2019年4月23日,这是一个什么日子呢? 如果我没有看日历的提醒,我其实也不忘记了这是什么日子。每一年的4月23日是世界读书日,世界读书日你读书了吗?昨天我是没有真正读书的,昨天下班比较晚,回到家吃饭洗漱完快十二点了,想着第二天还要上班,就睡觉了。今天刷CSDN看到征文活动: “征文|@程序员 你读过的书,…

    2022年2月28日
    42
  • 【教程】最简单的Claude Code Router(ccr)配置教程,低成本使用claude code

    【教程】最简单的Claude Code Router(ccr)配置教程,低成本使用claude code

    2026年3月16日
    3

发表回复

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

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