码迷,mamicode.com
首页 > 其他好文 > 详细

SGU 281.Championship

时间:2015-07-24 15:49:41      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:

题意:

  有n(n≤50000)支队伍参加了两场比赛,分别有两个排名。现在要求输出总排名,如果对任意m,在两个排名的前m个队伍都相同,那么在总排名前m个队伍就是这些队伍。其它情况按字典序排。

 

 


Solution:

  简单题。

  先map定位每个队伍在第一个排名中的位置。从第二个排名的第一个开始,找到最小满足条件的m,对这m个队伍按照字典序进行排序。然后继续找新的m(不包括排完序的队伍)直到所有队伍排完。

 

 

技术分享
#include <iostream>
#include <algorithm>
#include <cstring>
#include <vector>
#include <map>
using namespace std;
map<string, int> pos;
vector<string> Rank;
int n;
int main()
{
    ios::sync_with_stdio ( 0 );
    cin >> n;
    string name;
    for ( int i = 1; i <= n; ++i ) {
        cin >> name;
        pos[name] = i;
    }
    int r = 0, l = 0;
    for ( int i = 1; i <= n; ++i ) {
        cin >> name;
        Rank.push_back ( name );
        r = max ( r, pos[name] );
        if ( i == r ) {
            sort ( Rank.begin() + l, Rank.begin() + r );
            l = r;
        }
    }
    for ( int i = 0; i < n; ++i ) {
        cout << Rank[i] << "\n";
    }
}
View Code

 

SGU 281.Championship

标签:

原文地址:http://www.cnblogs.com/keam37/p/4673502.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!