流利说礼物派发

思路:先求出每个cost[i][0]-cost[i][1]的差值,然后进行排序,将差值最大的b个送往乙地,其余送往甲地,即为最小费用。
代码:
bool cmp1(const vector<int>& aa, const vector<int>& bb)
{
return aa[0]-aa[1] > bb[0]-bb[1];
}

int LeastCost(vector<vector<int>>& cost,int a, int b) {
int res = 0;
//自定义方法cmp1,按差值排序
sort(cost.begin(), cost.end(), cmp1);
for(int i = 0; i < b; ++i) {
res += cost[i][1];
}
for(int i = b; i < costs.size(); ++i) {
res += cost[i][0];
}
return res;
}
int main(){
int n,a,b;
cin>>n;
cin>>a>>b;
vector<vector<int>> cost;
int i=0;
while(n--){
cout<<cost[i][0]<<cost[i][1];
i++;
}
int res=LeastCost(cost,a,b);
cout<<res;
return 0;
}


#流利说##笔试题目#
全部评论
这个题好像leetcode上有
点赞 回复 分享
发布于 2019-09-11 23:17
有个问题,要都是负数,要先送往甲地
点赞 回复 分享
发布于 2019-09-11 23:06
我也是这么写,但是只能过83.33号
点赞 回复 分享
发布于 2019-09-11 22:53
这是什么语言,大佬
点赞 回复 分享
发布于 2019-09-11 22:50

相关推荐

不愿透露姓名的神秘牛友
07-08 11:16
点赞 评论 收藏
分享
06-25 16:25
梧州学院 Java
愿汐_:项目介绍那么长,然而你做了啥就一句话?
点赞 评论 收藏
分享
废物一个0offer:认真的吗二本本科找人工智能岗位
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 12:04
毕业生招你惹你了,问一个发薪日来一句别看网上乱七八糟的你看哪个工作没有固定发薪日扭头就取消了面试就问了一句公司都是这个态度吗还搞上人身攻击了...
程序员小白条:呃呃呃,都还没面试,我都不会问这么细,何况通不通过,去不去都另说,你没实力和学历的话,在外面就这样,说实话没直接已读不回就不错了,浪费时间基本上
点赞 评论 收藏
分享
评论
点赞
3
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务