【USACO】贪婪的礼物送礼者
題目描述
對(duì)于一群要互送禮物的朋友,你要確定每個(gè)人收到的禮物比送出的多多少。 在這一個(gè)問題中,每個(gè)人都準(zhǔn)備了一些錢來送禮物,而這些錢將會(huì)被平均分給那些將收到他的禮物的人。 然而,在任何一群朋友中,有些人將送出較多的禮物(可能是因?yàn)橛休^多的朋友),所以有些人就準(zhǔn)備了較多的錢。 給出一群朋友, 沒有誰(shuí)的名字會(huì)長(zhǎng)于 14 個(gè)字符,給出每個(gè)人將花在送禮上的錢,和將收到他的禮物的人的列表,請(qǐng)確定每個(gè)人收到的比送出的錢多的數(shù)目。
輸入
| 第?1?行: | 人數(shù)NP,2<= NP<=10 ? |
第?2到?NP+1行: | 這NP個(gè)在組里人的名字 一個(gè)名字一行 |
第NP+2到最后: | 這里的NP段內(nèi)容是這樣組織的: |
輸出
輸出?NP?行
每行是一個(gè)的名字加上空格再加上收到的比送出的錢多的數(shù)目。
對(duì)于每一個(gè)人,他名字的打印順序應(yīng)和他在輸入的2到NP+1行中輸入的順序相同。所有的送禮的錢都是整數(shù)。
每個(gè)人把相同數(shù)目的錢給每位要送禮的朋友,而且盡可能多給,不能給出的錢被送禮者自己保留。
樣例輸入
5 dave laura owen vick amr dave 200 3 laura owen vick owen 500 1 dave amr 150 2 vick owen laura 0 2 amr vick vick 0 0?樣例輸出
dave 302 laura 66 owen -359 vick 141 amr -150提示
思路:暴力匹配,存下送出的錢和收到的錢就ok了
代碼:
#include<cstdio> #include<cmath> #include<cstring> #include<string> #include<cstdlib> #include<algorithm> #include<iostream> #include<queue> #include<stack> #include<map>using namespace std;#define FOU(i,x,y) for(int i=x;i<=y;i++) #define FOD(i,x,y) for(int i=x;i>=y;i--) #define MEM(a,val) memset(a,val,sizeof(a)) #define PI acos(-1.0)const double EXP = 1e-9; typedef long long ll; typedef unsigned long long ull; const int INF = 0x3f3f3f3f; const ll MINF = 0x3f3f3f3f3f3f3f3f; const int mod = 1e9+7; const int N = 1e6+5;struct node {string name;int num;int ans;int son; }a[15];int main() {//freopen("in.txt","r",stdin);//freopen("out.txt","w",stdout);std::ios::sync_with_stdio(false);int n;string s;int x,y;while(cin>>n){for(int i=1;i<=n;i++){cin>>a[i].name;a[i].ans=0;a[i].son=0;}int t=n;while(t--){cin>>s>>x>>y;if(y==0)continue;int tmp=x/y;int tmp2=x%y;for(int i=1;i<=n;i++){if(s==a[i].name){a[i].son=x-tmp2;while(y--){cin>>s;for(int j=1;j<=n;j++){if(a[j].name==s){a[j].ans+=tmp;break;}}}break;}}}for(int i=1;i<=n;i++)cout<<a[i].name<<" "<<a[i].ans-a[i].son<<endl;}return 0; }總結(jié)
以上是生活随笔為你收集整理的【USACO】贪婪的礼物送礼者的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Android给文档加水印,androi
- 下一篇: 源码分享 | 一个聚合的今日热榜站