这是第三题:最短耗时(难度:⭐⭐☆☆☆)

C++解法
3.最短耗时:
系统需要执行任务列表,系统可以随意选取需要执行的任务,每个任务的执行时间均为1s,但执行相同的任务期间会有cd,执行完一个任务后不能紧接着继续执行相同任务,必须等待cd结束。
第一行输入需要执行的任务名称列表,第二行输入执行相同任务的cd,请你输出任务被执行完毕的最短耗时。
例:
输入:

1,3,3,5,3,2,5,2,5,5,5
1

输出:

11

输入:

2,2,2,3
2

输出:

7
#include <iostream>
#include <sstream>
#include <map>
#include <vector>
#include <algorithm>

using namespace std;

int main() {
	int k, time = 0;
	string input, tmp;
	cin >> input;
	cin >> k;

	istringstream istst(input);
	map<int, int> taskcount;
	while (getline(istst, tmp, ','))
		taskcount[stoi(tmp)]++;

	vector<vector<int>> tasklist;
	for (auto i : taskcount) {
		tasklist.push_back(vector<int>());
		tasklist[tasklist.size() - 1].push_back(i.first);
		tasklist[tasklist.size() - 1].push_back(i.second);
		tasklist[tasklist.size() - 1].push_back(0);
	}
	sort(tasklist.begin(), tasklist.end(), [](vector<int>& a, vector<int>& b) { return a[1] > b[1]; });

	while (!tasklist.empty()) {
		for (int i = 0; i < tasklist.size(); i++) {
			int mincd = 100;
			time += (tasklist[i][2] + 1);
			tasklist[i][1]--;
			for (auto& j : tasklist) {
				if (j[2] > tasklist[i][2] + 1)
					j[2] -= (tasklist[i][2] + 1);
				else { j[2] = 0; }
			}
			tasklist[i][2] = k;
			if (tasklist[i][1] == 0) { tasklist.erase(tasklist.begin() + i); }

			sort(tasklist.begin(), tasklist.end(), [](vector<int>& a, vector<int>& b) { return a[1] > b[1]; });
			for (int j = 0; j < tasklist.size(); j++) {
				if (tasklist[j][2] < mincd) {
					mincd = tasklist[j][2];
					i = j - 1;
				}
			}
		}
	}
	cout << time << endl;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值