[关闭]
@Chilling 2016-08-23T17:39:33.000000Z 字数 3384 阅读 903

Easy Problemset(模拟)


Input file: easy.in
Output file: easy.out

Description

Perhaps one of the hardest problems of any ACM ICPC contest is to create a problemset with a reasonable number of easy problems. On Not Easy European Regional Contest this problem is solved as follows.

There are n jury members (judges). They are numbered from 1 to n. Judge number i had prepared easy problems before the jury meeting. Each of these problems has a hardness between 0 and 49 (the higher the harder). Each judge also knows a very large (say infinite) number of hard problems (their hardness is 50). Judges need to select k problems to be used on the contest during this meeting.

They start to propose problems in the ascending order of judges numbers. The first judge takes the first problem from his list of remaining easy problems (or a hard problem, if he has already proposed all his easy problems) and proposes it. The proposed problem is selected for the contest if its hardness is greater than or equal to the total hardness of the problems selected so far, otherwise it is considered too easy. Then the second judge does the same etc.; after the n-th judge, the first one proposes his next problem, and so on. This procedure is stopped immediately when k problems are selected.

If all judges have proposed all their easy problems, but they still have selected less than k problems, then they take some hard problems to complete the problemset regardless of the total hardness.

Your task is to calculate the total hardness of the problemset created by the judges.

Input

The first line of the input file contains the number of judges n (2 ≤ n ≤ 10) and the number of problems k (8 ≤ k ≤ 14). The i-th of the following n lines contains the description of the problems prepared by the i-th judge. It starts with (1 ≤ ≤ 10) followed by pi non negative integers between 0 and 49 — the hardnesses of the problems prepared by the i-th judge in the order they will be proposed.

Output

Output the only integer — the total hardness of the selected problems.


Sample input

3 8
5 0 3 12 1 10
4 1 1 23 20
4 1 5 17 49

3 10
2 1 3
1 1
2 2 5

Sample output

94
354

Hint

In the first example, three problems with hardnesses of 0, 1, and 1 are selected first. Then the first judge proposes the problem with hardness 3 and it is selected, too. The problem proposed by the second judge with hardness 1 is not selected, because it is too easy. Then the problems proposed by the third, the first, and the second judges are selected (their hardnesses are 5, 12 and 23). The following three proposed problems with hardness of 17, 1 and 20 are not selected, and the problemset is completed with a problem proposed by the third judge with hardness of 49. So the total hardness of the problemset is 94.

In the second example, three problems with hardnesses of 1, 1, and 2 are selected first. The second problem of the first judge (hardness 3) is too easy. The second judge is out of his easy problems, so he proposes a problem with hardness 50 and it is selected. The third judge’s problem with hardness 5 is not selected. The judges decide to take 6 more hard problems to complete the problemset, which gives the total hardness of 54 + 6 · 50 = 354.

题意:输入n,k,以下有n行,每行开头一个值x,后面跟x个数,要从这n行数字当中选取满足条件的k个数。选取数字是一列一列从上到下选,从第一列到最后一列。将选择的数字要大于等于已选数字之和。如果这列这个位置是空的,那么把它当作50。如果选的数字个数不到k个,那么差的数字都用50补上,问最后的值是多少。

分析:二维数组,先全部置成-1,然后输入,并且记录最长的一排的长度m。之后就要循环这m列…按题目要求判断然后加起来就可以了


  1. #include<stdio.h>
  2. #include<string.h>
  3. #include<algorithm>
  4. using namespace std;
  5. int a[20][20];
  6. int main()
  7. {
  8. freopen("easy.in","r",stdin);
  9. freopen("easy.out","w",stdout);
  10. int n,k,x,m;
  11. int sum,count;
  12. while(scanf("%d%d",&n,&k)!=EOF)
  13. {
  14. sum=0,m=-1,count=0;
  15. memset(a,-1,sizeof(a));
  16. for(int i=1;i<=n;i++)
  17. {
  18. scanf("%d",&x);
  19. m=max(m,x);
  20. for(int j=1;j<=x;j++)
  21. scanf("%d",&a[i][j]);
  22. }
  23. for(int i=1;i<=m;i++)
  24. {
  25. for(int j=1;j<=n;j++)
  26. {
  27. if(a[j][i]!=-1&&a[j][i]>=sum)
  28. {
  29. count++;
  30. sum+=a[j][i];
  31. }
  32. if(a[j][i]==-1&&50>=sum)
  33. {
  34. count++;
  35. sum+=50;
  36. }
  37. }
  38. if(count==k)
  39. break;
  40. }
  41. printf("%d\n",sum+(k-count)*50);
  42. }
  43. return 0;
  44. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注