CF 2A Winner

原创 2012年03月28日 22:29:39

也是简单的实现题,还是在学习大牛的代码!

我的代码:

#include <iostream>
#include <algorithm>
using namespace std;

struct P
{
    string name;
    int s;
}p1[1010],p2[1010];
bool cmp(P a,P b)
{
    return a.s > b.s;
}
int main()
{
    int n,i,j,k,k1;
    P tmp;
    while(cin>>n)
    {
        k = 0;k1 = 0;
        for(i = 0;i < n;i ++)
        {
            cin>>tmp.name>>tmp.s;
            for(j = 0;j < k;j ++)
            {
                if(p1[j].name == tmp.name){ p1[j].s += tmp.s;p2[k1].name = tmp.name;p2[k1++] = p1[j];break;}
            }
            if(j == k) {p1[k++] = tmp;p2[k1++] = tmp;}
        }
        sort(p1,p1+k,cmp);
        int  l = p1[0].s;
        for(i = 0;i < k1;i ++)
        {
            if(p2[i].s >= l)
            {
                for(j = 0;j < k;j ++)
                {
                    if(p1[j].name == p2[i].name&&p1[j].s == l)
                    {
                        cout<<p1[j].name<<endl;
                        i = k1;
                        break;
                    }
                }
            }
        }
    }
}
用了map后的代码:简洁了很多。

#include <iostream>
#include <map>
#include <string.h>
#include <algorithm>
using namespace std;
int score[1010];
map<string, int> p1,p2;
string name[1010];
int main()
{
    int n,i,j;
    while(cin>>n)
    {
        int m = 0;
        for(i = 0;i < n;i ++)
        {
            cin>>name[i]>>score[i];
            p1[name[i]] += score[i];
        }
        for(i = 0;i < n;i ++)
        if(p1[name[i]] > m) m = p1[name[i]];
        for(i = 0;i < n;i ++)
        {
            p2[name[i]] += score[i];
            if(p2[name[i]] >= m&&p1[name[i]] == m)
            {
                cout<<name[i]<<endl;
                break;
            }
        }
    }
}


相关文章推荐

CF 2A

传送门:http://codeforces.com/problemset/problem/2/A 题意:给你一个数N,代表N轮游戏,接下来N行给出没轮某人的得分,求N轮后最高得分者是谁,若有...
  • Ac__pyt
  • Ac__pyt
  • 2015年05月18日 10:27
  • 201

cf 2a Winner

#include #include #include using namespace std; string ss[1005]; int x[1005]; int main() { in...

CodeForces 2A - Winner(模拟)

CodeForces 2A - Winner(模拟)

Codeforces 2A Winner

EnglishDescThe winner of the card game popular in Berland “Berlogging” is determined according to th...

[codeforces] 2A - Winner

原题地址:http://codeforces.com/problemset/problem/2/A 英文渣,原题看了半天理解错了,然后各种WA,回头看了一下才发现其实是挺简单的。 意思就是一群人玩...
  • scruelt
  • scruelt
  • 2016年09月23日 09:35
  • 89

Codeforces 2A Winner (STL map使用)

A. Winner time limit per test 1 second memory limit per test 64 megabytes input st...

Codeforces 2 A. Winner

哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈。。。。。。。 先让我笑完。。。。。。。。。。。。。。。。 就是一道撒比题啊,一开始是题目看错= =、是,但是后面还是自己不仔细错的。。。。。不存在题目坑这种...

CODEFORCES 2A-Winner

这是codeforce上的2A,被这道题折磨了很长一段时间,想想就很不爽。。。。 关于这道题目,更详细的地方看这里:A. Winner; 好了,不发牢骚直接进入主题,首先来看看这道题目: The...

codeforces - 2A - Winner

Winner time limit per test 1 second memory limit per test 64 megabytes input stand...

Codeforces 2A Winner (map运用)

Winner Time Limit: 1000ms Memory Limit: 65536KB This problem will be judged on CodeForces. ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:CF 2A Winner
举报原因:
原因补充:

(最多只允许输入30个字)