【解题报告】瑞士轮(NOIP2011普及组T3)
【题外话:这道题吧……说实话我不太喜欢……因为卡快排。】
题目不贴了,就是给你一个赛制,然后各个选手的初始得分和能力值,问你进行R轮比赛之后第Q名的编号是多少(这个编号读进来就要算OYZ,初始快排的时候也要注意。)
我是用的比较常规的方法,每次扫描整个序列,计算胜者和负者,分入两个数组,然后把这两个数组归并回原来的序列里(因为这两个序列都已经有序,所以可以免去排序直接合并),题目中要求编号小的排在前面,因为归并是稳定排序所以不需要担心这些。
其实本质来说就是个讲究技巧的模拟吧?
下贴代码,风格照样丑。
#include <algorithm>
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <cstring>
#include <cmath>
using namespace std;
ifstream fin("swiss.in");
ofstream fout("swiss.out");
struct per
{
int fs;
int nl;
int bh;
};
per player[];
int Rs=,ls=,gz=;
per winner[]={},loser[]={};
void Heib();
bool px(per a,per b);
int main(void)
{
fin>>Rs>>ls>>gz;
Rs*=;
for(int i=;i<=Rs;i++)
{
fin>>player[i].fs;
player[i].bh=i;
}
for(int i=;i<=Rs;i++)fin>>player[i].nl;
sort(player+,player+Rs+,px);
for(int i=;i<=ls;i++)
{
for(int j=;j<=Rs;j++)
{
if(j%==)
{
if(player[j].bh==||player[j-].bh==)
{
}
if(player[j].nl>player[j-].nl)
{
winner[j/].bh=player[j].bh;
winner[j/].fs=player[j].fs+;
winner[j/].nl=player[j].nl;
loser[j/].bh=player[j-].bh;
loser[j/].fs=player[j-].fs;
loser[j/].nl=player[j-].nl;
}
else
{
winner[j/].bh=player[j-].bh;
winner[j/].fs=player[j-].fs+;
winner[j/].nl=player[j-].nl;
loser[j/].bh=player[j].bh;
loser[j/].fs=player[j].fs;
loser[j/].nl=player[j].nl;
}
}
}
Heib();
}
fout<<player[gz].bh;
return ;
} bool px(per a,per b)
{
if(a.fs>b.fs)return ;
if(a.fs==b.fs&&a.bh<b.bh)return ;
if(a.fs==b.fs&&a.bh>b.bh)return ;
return ;
} void Heib()
{
int lf=,rt=,zz=;
while(lf<=Rs/&&rt<=Rs/)
{
if(winner[lf].fs>loser[rt].fs||(winner[lf].fs==loser[rt].fs&&winner[lf].bh<loser[rt].bh))
{
player[zz].bh=winner[lf].bh;
player[zz].fs=winner[lf].fs;
player[zz].nl=winner[lf].nl;
zz++;
lf++;
}
if(winner[lf].fs<loser[rt].fs||(winner[lf].fs==loser[rt].fs&&winner[lf].bh>loser[rt].bh))
{
player[zz].bh=loser[rt].bh;
player[zz].fs=loser[rt].fs;
player[zz].nl=loser[rt].nl;
zz++;
rt++;
}
}
while(lf<=Rs/||rt<=Rs/)
{
if(lf<=Rs/)
{
player[zz].bh=winner[lf].bh;
player[zz].fs=winner[lf].fs;
player[zz].nl=winner[lf].nl;
lf++;
}
if(rt<=Rs/)
{
player[zz].bh=loser[rt].bh;
player[zz].fs=loser[rt].fs;
player[zz].nl=loser[rt].nl;
rt++;
}
zz++;
}
return;
}
【题外话2:其实两篇解题报告之间我还A了几道题,不过都太简单或者太恶心到我不想写题解……OYZ】
【题外话3:这里是个准初三狗,一开学成了初三狗之后估计就不会太快更新了……】
【解题报告】瑞士轮(NOIP2011普及组T3)的更多相关文章
- NOIP2011 普及组 T3 洛谷P1309 瑞士轮
今天题做太少,放道小题凑数233 题目背景 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点是比赛场数少,每场都紧张刺激,但偶然性较高.后者的特点是较为公 ...
- [NOIP2011普及组]瑞士轮 JAVA实现
题目描述 2*N名编号为1~2N的选手共进行R轮比赛.每轮比赛开始前,以及所有比赛结束后,都会按照总分从高到低对选手进行一次排名.选手的总分为第一轮开始前的初始分数加上已参加过的所有比赛的得分和.总分 ...
- NOIP2008 普及组T3 传球游戏 解题报告-S.B.S.
题目描述 上体育课的时候,小蛮的老师经常带着同学们一起做游戏.这次,老师带着同学们一起做传球游戏. 游戏规则是这样的:n个同学站成一个圆圈,其中的一个同学手里拿着一个球,当老师吹哨子时开始传球,每个同 ...
- NOIP2011普及组 瑞士轮
OJ地址: https://www.luogu.org/problemnew/show/P1309 http://bailian.openjudge.cn/practice/4031/ 总时间限制: ...
- NOIP2012 普及组 T3 摆花——S.B.S.
题目描述 小明的花店新开张,为了吸引顾客,他想在花店的门口摆上一排花,共m盆.通过调查顾客的喜好,小明列出了顾客最喜欢的n种花,从1到n标号.为了在门口展出更多种花,规定第i种花不能超过ai盆,摆花时 ...
- [NOIP2011] 普及组
数字反转 小模拟 #include<cstdio> #include<iostream> #include<cstring> using namespace std ...
- NOIP2011普及组 数字反转
题目OJ链接: http://codevs.cn/problem/1130/ https://www.luogu.org/problemnew/show/P1307 2011年NOIP全国联赛普及组 ...
- 【单调队列】Vijos P1771 瑞士轮 (NOIP2011普及组第三题)
题目链接: https://vijos.org/p/1771 题目大意: 给定2N个人(N<=100 000)和其初始分数.能力值(能力两两不同),比赛M次(M<=50),每次PK都是按分 ...
- NOIP2011普及组 瑞士环 保序性
题目链接:http://noi.openjudge.cn/ch0401/4363/ 分析:如果直接模拟,时间复杂度是O(r*nlogn)超时 然后我们发现每次一轮开始时,刚开始是保序的,然后我们可以把 ...
随机推荐
- [HMLY]8.Cocoa
cocoa是苹果公司为mac os x所创建的原声面向对象API,是mac os x上五大API之一,其他四个是carbon,posiX,x11,java. 苹果的面向对象开发框架,用来生成 Mac ...
- 基于python第三方requests 模块的HTTP请求类
使用requests模块构造的下载器,首先安装第三方库requests pip install requests 1 class StrongDownload(object): def __init_ ...
- mysql报错1024-can't get hostname for your address
前一段时间mysql用的好好的,突然一天,mysql启动后,在使用navicat连接数据库的时候 报错1024-can't get hostname for your address 这里我是这样解决 ...
- 关于Two-Pass标记连通域个数
关于Two-Pass标记连通域个数 背景 在完成图像的一系列处理后,得到二值图,一般会统计目标数量,即是获取连通域个数,这里采用TwoPass的方法. 基本思想 在Two-pass连通域标记中,第一次 ...
- 关于VS2010编译警告LNK4221
最近研究duilib,准备把里面自定义的一些工具类如CDuiString什么的用ATL的替换掉,于是遇到久仰大名的 warning C4251: xxx needs to have dll-int ...
- 一点公益二码公益开发模式系统源码App
写这篇文章,是因为最近看到的一个著名的开源项目在内部使用时的各种问题,不得不说,很多的开源的东西思想是不错的,但离真正工程化都有不小的距离,所以没什么商业公司采用的开源产品如果要引入的话一定要慎重,通 ...
- 第1章 PHP快速入门
1.最好使用<?php ?> 即XML风格的PHP标记: 2.echo语句:将传递给其自身的字符串打印到浏览器: 3.注释:①C风格的多行注释/* */ ②C++风格的单行注释// ...
- 前端自动化部署之gulp
1.首先需要安装node+npm(这里不再叙述,网上教程一大堆) 2.gulp全局安装:npm install -g gulp 3.cd进入到你的项目目录,这里使用demo文件夹为我的示例项目 4.在 ...
- Openjudge-NOI题库-Pell数列
题目描述 Description Pell数列a1, a2, a3, ...的定义是这样的,a1 = 1, a2 = 2, ... , an = 2 * an − 1 + an - 2 (n > ...
- yahoo给出的关于网站优化的建议
1.使用CDN 内容分发服务器会根据用户的位置选择最近的服务器响应用户的请求,静态资源放在CDN的性能将提升20%左右. 2.设置Expires和Cache-Contral头 将静态资源的过期时间设置 ...