[LeetCode]1029. 两地调度 原创
题目来源 LeetCode
算法标签 贪心
题目描述
公司计划面试 2N 人。第 i 人飞往 A 市的费用为 costs[i][0],飞往 B 市的费用为 costs[i][1]。
返回将每个人都飞到某座城市的最低费用,要求每个城市都有 N 人抵达。
示例:
输入:[[10,20],[30,200],[400,50],[30,20]]
输出:110
解释:
第一个人去 A 市,费用为 10。
第二个人去 A 市,费用为 30。
第三个人去 B 市,费用为 50。
第四个人去 B 市,费用为 20。
最低总费用为 10 + 30 + 50 + 20 = 110,每个城市都有一半的人在面试。
提示:
1 <= costs.length <= 100
costs.length 为偶数
1 <= costs[i][0], costs[i][1] <= 1000
通过次数9,070提交次数14,866
思路
贪心
题目的意思就是两个城市都有一半人
要最优惠的价格
则 我们假设所有人去A,我们则肯定需要一半人去B
怎么选择着一半人,则是查找B-A正数差值最大的一半人
减去差值之后我们就相当于一半人去了A,一半人去了B,且是最优惠价格
AC代码
class Solution {
public:
int twoCitySchedCost(vector<vector<int>>& costs) {
int sum = 0;
for(int i=0;i<costs.size();i++)sum+=costs[i][0];
vector<int> arr;
for(int i=0;i<costs.size();i++)arr.push_back(costs[i][0]-costs[i][1]);
sort(arr.begin(), arr.end());
for(int i=arr.size()-1;i>=arr.size()>>1;i--)sum-=arr[i];
return sum;
}
};
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具