拼多多笔试

赛后重写了第二题,换方法,考虑区间维护,也不知道思路对不对,求指点!
#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int main()
{
	int t;
	cin >> t;
	while (t--) {
		int n, v;
		cin >> n >> v;
		int N = 3000 + 1;
		vector<int> k(n), a(n), b(n);
		int data = 0;
		for (int i = 0; i < n; i++) {
			cin >> k[i] >> a[i] >> b[i];
			data = max(data, b[i]);
		}
		vector<int> d1(N, 0), d2(N, 0), d3(N, 0);
		for (int i = 0; i < n; i++) {
			d1[a[i]] += k[i];
			d2[b[i] + 1] += k[i];
		}
		for (int i = 1; i <= data; i++) {
			d1[i] += d1[i - 1];
			d2[i] += d2[i - 1];
		}
		for (int i = 1; i <= data; i++) {
			d3[i] = d3[i - 1] + min(v, d1[i] - max(d2[i], d3[i - 1]));
		}
		cout << d3[data] << endl;
	}
	return 0;
}

#面试复盘##拼多多##笔经#
全部评论
1 3 1 10 1 100 1 1 1 2 2 2
点赞
送花
回复
分享
发布于 2022-03-20 23:00
大佬a了几道
点赞
送花
回复
分享
发布于 2022-03-20 23:32
滴滴
校招火热招聘中
官网直投
根据b的值做个排序就好了
点赞
送花
回复
分享
发布于 2022-03-21 18:03

相关推荐

点赞 3 评论
分享
牛客网
牛客企业服务