首页 > 其他 > 详细

UVALive 2521 Game Prediction 题解

时间:2016-07-31 17:14:48      阅读:236      评论:0      收藏:0      [点我收藏+]

  这个我上来把题目理解错了,我以为所有人的牌都是一样的,感觉这个题太麻烦了吧,而且题目样例过不去啊……后来发现理解错了,给出的数据是他一个人的数据,就是让我们求他一定能赢的轮数,所有的牌是固定的(1 - n×m),然后就去找当前最大值就可以了,不断的更新被打出的牌,就可以求出答案了。

代码如下:

#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;

int data[50];

bool cmp(int a,int b)
{
    return a>b;
}

int main()
{
    int n,m,cas=0;
    while(~scanf("%d%d",&m,&n),m)
    {
        for (int i=1;i<=n;i++)
        {
            scanf("%d",&data[i]);
        }
        sort(data+1,data+1+n,cmp);
        int ll=0,cnt=0;
        for (int maxn=m*n,i=1;i<=n,maxn>=1;maxn--)
        {
            if (maxn==data[i])
            {
                i++;
                if (ll==0)
                {
                    cnt++;
                }
                else
                {
                    ll--;
                }
            }
            else
                ll++;
        }
        printf("Case %d: %d\n",++cas,cnt);
    }
    return 0;
}

 

UVALive 2521 Game Prediction 题解

原文:http://www.cnblogs.com/jifahu/p/5723212.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!