牛客网之网易面试题
输入描述:
每个输入包含一个测试用例。
每个测试用例的第一行包含两个正整数,分别表示工作的数量N(N<=100000)和小伙伴的数量M(M<=100000)。
接下来的N行每行包含两个正整数,分别表示该项工作的难度Di(Di<=1000000000)和报酬Pi(Pi<=1000000000)。
接下来的一行包含M个正整数,分别表示M个小伙伴的能力值Ai(Ai<=1000000000)。
保证不存在两项工作的报酬相同。
输出描述:
对于每个小伙伴,在单独的一行输出一个正整数表示他能得到的最高报酬。一个工作可以被多个人选择。
输入例子1:
3 3 1 100 10 1000 1000000000 1001 9 10 1000000000
C# 代码
public void GetMn(int n,int m) { //输入测试实列N和M //N为工作的数量,M为小伙伴的数量 Dictionary<int, int> map = new Dictionary<int, int>(); int t1 = 0, t2 = 0; int[] a = new int[n]; //n的值 int[] b = new int[m]; //存储m的值 int[] shu = new int[n]; //存储金额最大 //N行每行包含两个正整数,分别表示该项工作的难度Di(Di<=1000000000)和报酬Pi(Pi<=1000000000)。 for (int i = 0; i < n; i++) { t1 = Convert.ToInt32(Console.ReadLine()); //Di t2 = Convert.ToInt32(Console.ReadLine()); //Pi a[i] = t1; //Di map.Add(t1, t2); //对应难度和工资 } //接下来的一行包含M个正整数,分别表示M个小伙伴的能力值Ai(Ai<=1000000000)。 for (int j = 0; j < m; j++) { t1 = Convert.ToInt32(Console.ReadLine()); //M个整数 //a[n + j] = t1; b[j] = t1; //存储m if (!map.ContainsKey(t1)) map.Add(t1, 0); } int max = 0; for (int i = 0; i <n; i++) { max = Math.Max(max, map[a[i]]); shu[i] = max; } for (int i = 0; i < shu.Length; i++) { Console.WriteLine(shu[i]); } }
版权声明:本文为mengluo原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。