版权声明:版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a458383896/article/details/84338067
题目:
对于一群(NP个)要互送礼物的朋友,GY要确定每个人送出的钱比收到的多多少。在这一个问题中,每个人都准备了一些钱来送礼物,而这些钱将会被平均分给那些将收到他的礼物的人。然而,在任何一群朋友中,有些人将送出较多的礼物(可能是因为有较多的朋友),有些人有准备了较多的钱。给出一群朋友,没有人的名字会长于 14 字符,给出每个人将花在送礼上的钱,和将收到他的礼物的人的列表,请确定每个人收到的比送出的钱多的数目。
输入格式:
第 1 行: 人数NP,2<= NP<=10
第 2 行 到 第NP+1 行:这NP个在组里人的名字一个名字一行
第NP+2到最后:
这里的I段内容是这样组织的:
第一行是将会送出礼物人的名字。
第二行包含二个数字:第一个是原有的钱的数目(在0到2000的范围里),第二个 NGi 是将收到这个人礼物的人的个数 如果 NGi 是非零的, 在下面 NGi 行列出礼物的接受者的名字,一个名字一行。
样例:
输入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
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.HashMap;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
int cnt = Integer.parseInt(in.readLine());
HashMap<String, Integer> map = new HashMap<String, Integer>();
String[] names = new String[cnt];
for (int i = 0; i < cnt; i++){
names[i] = in.readLine();
map.put(names[i], 0);
}
/**
* receiverCount 收到钱人数
* remainingMoney 剩下的钱
* receiverGetMoney 接受到的钱
*
*/
for (int i = 0; i < cnt; i++){
String name = in.readLine();
StringTokenizer st = new StringTokenizer(in.readLine());
int money = Integer.parseInt(st.nextToken());
int receiverCount = Integer.parseInt(st.nextToken());
if (receiverCount == 0){
continue;
}
int remainingMoney = money % receiverCount;
int receiverGetMoney = money / receiverCount;
map.put(name, map.get(name) - (money - remainingMoney));
for (int j = 0; j < receiverCount; j++){
String receiver = in.readLine();
map.put(receiver, map.get(receiver) + receiverGetMoney);
}
}
for (String s : names){
System.out.println(s + " " + map.get(s));
}
}
}