hdoj 4907 Task schedule 【预处理】

题意:中文题,你懂得。。。

思路:建两个数组,一个标记,一个放答案(就是最快能处理的任务点), 在输入数据的时候标记改位置已经有任务了,并且找出来一个最大的数max。然后从max+1,出发从大到小,依次用temp定义没有任务的序号,如果是没有被标记那么就将该处的答案定义为temp。

题目链接 点击打开链接

代码:

#include<stdio.h>
#include<string.h>
#define MAXN 200005
int vis[MAXN], ans[MAXN];
int main()
{
	int t, n, m, i, j, q;
	scanf("%d", &t);
	while(t --){
		int a;
		memset(vis, 0, sizeof(vis));
		memset(ans, 0, sizeof(ans));
		int k = 0;
		int max = 0;
		scanf("%d%d", &n, &m);
		for(i = 1; i <= n; i ++){
			scanf("%d", &a);
			vis[a] = 1;
			if(max < a)
			max = a;
		}
		int temp = max+1;
		for(i = max; i > 0; i --){
			if(vis[i])
			 ans[i] = temp;
			 else
			 temp = i;
		}
		while(m --){
			scanf("%d", &q);
			if(!vis[q]){
				printf("%d\n", q);
			}
			else
			printf("%d\n", ans[q]);
		}
	}
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值