欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

开机方案题解

程序员文章站 2022-06-19 10:22:37
题目描述 h 学长有个机器用来完成任务。 现在有 n 个任务,第 i 个任务(1现在 h 学长想利用自己具备的 k 点能量,有效的控制机器的开启,使得机器完成 n 个任务消耗的燃料尽可能的少。那么对应给出的 n 个任务以及 h 学长拥有的能量数,你能帮帮他吗? 提示:消耗的燃料要尽可能的少,即机器工 ......

题目描述

h 学长有个机器用来完成任务。
现在有 n 个任务,第 i 个任务(1<= i <= n) 在 ti 时刻开始,并在 ti + 1 时刻结束。同一时刻不会有多个任务。 h 学长可以在任何时刻开启机器,不过每一次开启机器都会消耗 1 点能量。h 学长只有 k 点能量可以用于开启机器。但是机器开着的时候需要消耗燃料,显然让机器一直开着并不一定是最好的选择。
现在 h 学长想利用自己具备的 k 点能量,有效的控制机器的开启,使得机器完成 n 个任务消耗的燃料尽可能的少。那么对应给出的 n 个任务以及 h 学长拥有的能量数,你能帮帮他吗?
提示:消耗的燃料要尽可能的少,即机器工作的时间尽可能的短。

输入格式:
第一行包括两个整数 n和 k(1<= n <= 1e5, 1<= k <=n) ,表示有 n 个任务和 h 学长拥有 k 点能量。
接下来 n 行,每行一个整数 ti(1<= ti <=1e9),表示第 i 个任务在 ti 时刻开始,并在 ti + 1 时刻结束 。

输出格式:
输出一行包含一个整数,表示机器工作的最少时间。

解题思路

1.相邻任务的时间间隔为 x[i]=t[i]-(t[i-1]+1)
2.机器第一次开启与最后一次关闭的时间差为 ans
3.对时间间隔排序,选择(k-1)个较大的时间间隔关闭机器,
即用 ans -(k-1)个较大的时间间隔

完整代码

#include<stdio.h>
#include<algorithm>
using namespace std;

int main()
{
	int n, k, i, j, ans;
	int t[100020], x[100020] = { 0 };
	scanf("%d%d", &n, &k);
	for (i = 0; i < n; i++) {
		scanf("%d", &t[i]);
		if (i != 0) {
			x[i] = t[i] - (t[i - 1] + 1);
		}/*xi为每两个任务的时间间隔*/
	}
	sort(x, x + n);
	ans = t[n - 1] - t[0] + 1;
	for (i = 1, j = n - 1; i <= k - 1 ; i++, j--) {
		ans -= x[j];
	}/*总任务时间扣除k-1个较大时间间隔*/
	printf("%d", ans);
	return 0;
}