Greedy Gift Givers java

版权声明:版权声明:本文为博主原创文章,未经博主允许不得转载。 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 行列出礼物的接受者的名字,一个名字一行。
 

样例: 
输入


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));
		}
	}
}

猜你喜欢

转载自blog.csdn.net/a458383896/article/details/84338067