输入描述:
每个输入包含一个测试用例。
每个测试用例的第一行包含两个正整数,分别表示工作的数量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]);
}
}