1093: 分香蕉

编程入门 行业动态 更新时间:2024-10-09 02:29:47

1093: 分<a href=https://www.elefans.com/category/jswz/34/1743488.html style=香蕉"/>

1093: 分香蕉

题目描述

现在有n个香蕉,每个香蕉的质量为ai,m只猴子,每只猴子的体重为bi。
现在将香蕉分给这些猴子,将猴子按照从大到小的顺序依次拿香蕉。当一轮拿完时,还有多的香蕉就会继续一个个拿,直到被拿完。
猴子都是聪明的,每次都会选择一个质量最大的香蕉。
现在请求出每个猴子获得的香蕉质量。

输入格式

第一行输入两个正整数n,m(1<=n,m<=10^5)
第二行n个整数ai表示每个香蕉的质量(1<=ai<=10^4)
第三行m个整数bi表示每个猴子的体重,保证体重互不相同。(1<=bi<=10^9)

输出格式

一行,m个用空格分隔的整数,表示每个猴子获得的香蕉质量之和。按照输入顺序输出对应的猴子。

输入样例 
5 3
1 2 3 4 5
3 2 1
输出样例 
7 5 3

 这里没想到什么很好的方法,就直接用结构体排序了

使用模运对数组赋值

#include <bits/stdc++.h>using namespace std;typedef long long int ll;
#define endl "\n"
const int  maxLine = 1e5+10;
// #define long long int ll;// bool cmp(const pair<char,int>& a,const pair<char,int>& b){
//     return a.second<b.second;
// }
// auto maxValue=max_element(mymap.begin(),mymap.end(),cmp);
// 猴子的序号和体重过
// prir<int,int> mypair[maxLine];
struct monky {int index;int w;int value;
};
struct monky ttt[maxLine];
// 体重排序
bool cmp(struct monky a,struct monky b){return a.w>b.w;
}bool cmp2(struct monky a,struct monky b){return a.index<b.index;
}int banana[maxLine];void print(struct monky arr[maxLine],int nums){for(int i=0;i<nums;i++){cout<<ttt[i].index<<" "<<ttt[i].w<<" "<<ttt[i].value<<endl;}cout<<endl;
}
void prints(int arr[maxLine],int nums){for(int i=0;i<nums;i++){cout<<arr[i]<<endl;}cout<<endl;
}
int main() {int m,n;cin>>m>>n;for(int i=0;i<m;i++){cin>>banana[i];}for(int i=0;i<n;i++){int w;cin>>w;ttt[i].index=i;ttt[i].w=w;}// 对香蕉降序sort(banana,banana+m,greater<int>());// 对猴子体重升序sort(ttt,ttt+n,cmp);for(int i=0;i<m;i++){ttt[i%n].value+=banana[i];}// 按照index升序sort(ttt,ttt+n,cmp2);for(int i=0;i<n;i++){cout<<ttt[i].value<<" ";}return 0;
}

更多推荐

1093: 分香蕉

本文发布于:2023-12-03 08:08:07,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1653033.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:香蕉

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!