zoukankan      html  css  js  c++  java
  • 洛谷 P1309 瑞士轮

    题目背景

    在双人对决的竞技性比赛,如乒乓球、羽毛球、国际象棋中,最常见的赛制是淘汰赛和循环赛。前者的特点是比赛场数少,每场都紧张刺激,但偶然性较高。后者的特点是较为公平,偶然性较低,但比赛过程往往十分冗长。

    本题中介绍的瑞士轮赛制,因最早使用于1895年在瑞士举办的国际象棋比赛而得名。它可以看作是淘汰赛与循环赛的折衷,既保证了比赛的稳定性,又能使赛程不至于过长。

    题目描述

    2*N 名编号为 1~2N 的选手共进行R 轮比赛。每轮比赛开始前,以及所有比赛结束后,都会按照总分从高到低对选手进行一次排名。选手的总分为第一轮开始前的初始分数加上已参加过的所有比赛的得分和。总分相同的,约定编号较小的选手排名靠前。

    每轮比赛的对阵安排与该轮比赛开始前的排名有关:第1 名和第2 名、第 3 名和第 4名、……、第2K – 1 名和第 2K名、…… 、第2N – 1 名和第2N名,各进行一场比赛。每场比赛胜者得1 分,负者得 0 分。也就是说除了首轮以外,其它轮比赛的安排均不能事先确定,而是要取决于选手在之前比赛中的表现。

    现给定每个选手的初始分数及其实力值,试计算在R 轮比赛过后,排名第 Q 的选手编号是多少。我们假设选手的实力值两两不同,且每场比赛中实力值较高的总能获胜。

    输入输出格式

    输入格式:

    输入文件名为swiss.in 。

    输入的第一行是三个正整数N、R 、Q,每两个数之间用一个空格隔开,表示有 2*N 名选手、R 轮比赛,以及我们关心的名次 Q。

    第二行是2*N 个非负整数s1, s2, …, s2N,每两个数之间用一个空格隔开,其中 si 表示编号为i 的选手的初始分数。 第三行是2*N 个正整数w1 , w2 , …, w2N,每两个数之间用一个空格隔开,其中 wi 表示编号为i 的选手的实力值。

    输出格式:

    输出文件名为swiss.out。

    输出只有一行,包含一个整数,即R 轮比赛结束后,排名第 Q 的选手的编号。

    输入输出样例

    输入样例#1:
    2 4 2 
    7 6 6 7 
    10 5 20 15 
    
    输出样例#1:
    1
    

    说明

    【样例解释】

    【数据范围】

    对于30% 的数据,1 ≤ N ≤ 100;

    对于50% 的数据,1 ≤ N ≤ 10,000 ;

    对于100%的数据,1 ≤ N ≤ 100,000,1 ≤ R ≤ 50,1 ≤ Q ≤ 2N,0 ≤ s1, s2, …, s2N≤10^8,1 ≤w1, w2 , …, w2N≤ 10^8。

    noip2011普及组第3题。

    归并排序 二路归并

    本菜鸡一直认为归并排序没用。。这道题让我怀疑人生。

    屠龙宝刀点击就送

    #include <algorithm>
    #include <cstdio>
    struct node
    {
        int num,s,w;
        bool operator<(node a)const
        {
            if(s==a.s) return num<a.num;
            else return s>a.s;
        }
    }xs[200005],win[100005],los[100005];
    int n,r,q;
    void merge_sort(int l,int r)
    {
        for(int i=0,j=0,k=0;k<n*2;++k)
        {
            if(i<r&&j<r)
            {
                if(win[i].s<los[j].s) xs[k]=los[j++];
                else if(win[i].s>los[j].s) xs[k]=win[i++];
                else if(win[i].s==los[j].s&&win[i].num<los[j].num) xs[k]=win[i++];
                else if(win[i].s==los[j].s&&win[i].num>los[j].num) xs[k]=los[j++];
            }
            else if(i<r&&j>=r) xs[k]=win[i++];
            else if(i>=r&&j<r) xs[k]=los[j++];
        }
    }
    int main()
    {
        scanf("%d%d%d",&n,&r,&q);
        for(int i=0;i<n*2;++i)
        {
            scanf("%d",&xs[i].s);
            xs[i].num=i+1;
        }
        for(int i=0;i<n*2;++i) scanf("%d",&xs[i].w);
       std::sort(xs,xs+n*2);
        for(;r--;)
        {
            for(int i=0;i<n;++i)
            {
                int a=xs[i*2].w,b=xs[i*2+1].w;
                if(a>b) 
                {
                    win[i]=xs[i*2];
                    los[i]=xs[i*2+1];
                    win[i].s++;
                }
                else if(a<b)
                {
                    win[i]=xs[i*2+1];
                    los[i]=xs[i*2];
                    win[i].s++;
                }
            }
            merge_sort(0,n);
        }
        printf("%d
    ",xs[q-1].num);
        return 0;
    }
    我们都在命运之湖上荡舟划桨,波浪起伏着而我们无法逃脱孤航。但是假使我们迷失了方向,波浪将指引我们穿越另一天的曙光。
  • 相关阅读:
    EntityFramework 启用迁移 EnableMigrations 报异常 "No context type was found in the assembly"
    JAVA 访问FTP服务器示例(2)
    NuGet Package Manager 更新错误解决办法
    JAVA 访问FTP服务器示例(1)
    RemoteAttribute 的使用问题
    诡异的 javascript 变量
    javascript apply用法
    Babun 中文乱码
    GSM呼叫过程
    转站博客园
  • 原文地址:https://www.cnblogs.com/ruojisun/p/7394518.html
Copyright © 2011-2022 走看看