因为太菜不会写P1310 表达式的值,就只能过来水两篇博客啦qwq

另外这个题我是开o2才过的(虽然是写了归并排序)(可能我太菜写的归并不是还可以“剪枝”吧qwq)哎,果真还是太菜啦qwq

所以准备写归并然后去题解学习正确的不用开O2就可以过的算法;

咱好像忘记添加链接了qwq:

瑞士轮【题目链接】


其实这个题打眼一看可以直接sort来做,但是这个题用sort还是太慢了qwq、开o2都只有70pts,因此这是逼着我重新复习一遍归并排序啊qwq:

About归并:

注意归并排序要开一个辅助数组f[k],k从1开始~n记录了排好序的数组,然后为了保证每次排序都有效所以最后要重新将f数组的值赋给a数组,归并排序的思想是把一个排序区间分成两个大概等长(因为会出现奇数个元素所以并不是一定完全等长)的区间,然后接着再分,直到每个区间都只剩一个元素,接下来合并两个区间,分别设指针i和j指向要合并的两个区间的头,然后进行比较,如果a[i]<a[j](假设从小到大排),那么令i++,同时k++,f[k]=a[i];否则的话,令j++,同时k++,f[k]=a[j];结束的条件是i>mid或j>end(排序的末端点),然后将i之后和j之后没有进行比较的数(因为归并是从最小区间(1)开始排序,因此当我们排一个区间长度时,它的左边部分和右边部分已经都是有序的啦)复制到f数组中。

CODE:(归并)

void msort(int str,int end){//from big to smasll
if(str==end) return;
int mid=(str+end)>>;
msort(str,mid);
msort(mid+,end);
int i=str,j=mid+,k=str;
while(i<=mid&&j<=end){
if(p[i]>p[j]){
r1[k]=p[i];
k++;i++;
}
else {
r1[k]=p[j];
k++;j++;
}
}
while(i<=mid){r1[k]=p[i];k++;i++;}
while(j<=end){r1[k]=p[j];k++;j++;}
for(int i=str;i<=end;i++){
p[i]=r1[i];
}
}

以下是朴素归并排序的瑞士轮CODE:

#include<bits/stdc++.h>

using namespace std;

int n,r,q;
struct node{
int num,s,w;
}p[],r1[]; bool cmp(node x,node y){
if(x.s==y.s) return x.num<y.num;
return x.s>y.s;
} void msort(int str,int end){//归并:from big to smasll
if(str==end) return;
int mid=(str+end)>>;
msort(str,mid);
msort(mid+,end);
int i=str,j=mid+,k=str;
while(i<=mid&&j<=end){
if(cmp(p[i],p[j])){
r1[k].s=p[i].s;
r1[k].num=p[i].num;
r1[k].w=p[i].w;
k++;i++;
}
else {
r1[k].s=p[j].s;
r1[k].num=p[j].num;
r1[k].w=p[j].w;
k++;j++;
}
}
while(i<=mid){r1[k].s=p[i].s;r1[k].num=p[i].num;r1[k].w=p[i].w;k++;i++;}
while(j<=end){r1[k].s=p[j].s;r1[k].num=p[j].num;r1[k].w=p[j].w;k++;j++;}
for(int i=str;i<=end;i++){
p[i].s=r1[i].s;
p[i].num=r1[i].num;
p[i].w=r1[i].w;//好像结构体可以整体赋值但这不是咱菜吗qwq
}
} int main(){
scanf("%d %d %d",&n,&r,&q);
for(int i=;i<=*n;i++)
scanf("%d",&p[i].s),p[i].num=i;
for(int i=;i<=*n;i++)
scanf("%d",&p[i].w);
sort(p+,p+*n+,cmp);
for(int i=;i<=r;i++){
for(int j=;j<=*n;j+=){
if(p[j].w>p[j+].w) p[j].s++;else p[j+].s++;//进行两两比较
}
msort(,*n);
}
cout<<p[q].num<<endl;
}

以下是大概是算了我去测试一下(逃 亲测可以不开o2就ac的思路

首先进行一遍sort,然后优化在于这里的思路只需要进行一次归并排序:

将比赛的输赢分别记录在一个数组中,赢的人记录在一起(win),输的人记录在一起(lose),并记录人数。因为一次比赛最多对每个人的成绩更改1,因此整个序列的顺序的波动(尤其当序列很长的时候)不会特别大,这样我们需要排序的数据就少了。对于每次比赛后,我们进行一次优化的归并排序:

  • 两个指针i和j,分别指向的是赢的所有人和输的所有人,当赢的人加上赢得的这一分比分后顺序发生改变,我们就更改这两个数组的顺序,然后将分数较低的继续与下一个比较。直到全部比较完成。
  • 这样归并就省去了排子区间的时间,而是直接对这一个区间进行排序,就不会T掉了;

以下附链接吧(咱也不能投人家的代码是吧,但是咱也不想写自己的代码)

关于瑞士轮(P1309)以及引申出来的种种问题

end-

【洛谷p1309】瑞士轮的更多相关文章

  1. 洛谷P1309 瑞士轮(归并排序)

    To 洛谷.1309 瑞士轮 题目背景 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点是比赛场数少,每场都紧张刺激,但偶然性较高.后者的特点是较为公平, ...

  2. 洛谷 P1309 瑞士轮 解题报告

    P1309 瑞士轮 题目背景 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点是比赛场数少,每场都紧张刺激,但偶然性较高.后者的特点是较为公平,偶然性较低 ...

  3. NOIP2011 普及组 T3 洛谷P1309 瑞士轮

    今天题做太少,放道小题凑数233 题目背景 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点是比赛场数少,每场都紧张刺激,但偶然性较高.后者的特点是较为公 ...

  4. 洛谷 P1309 瑞士轮

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

  5. 洛谷P1309——瑞士轮(归并排序)

    https://www.luogu.org/problem/show?pid=1309#sub 题目背景 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点 ...

  6. 洛谷P1309 瑞士轮

    传送门 题目大意: 2*n个人,有初始的比赛分数和实力值. 每次比赛前总分从大到小排序,总分相同编号小的排在前面. 每次比赛是1和2比,3和4比,5和6比. 实力值大的获胜得1分. 每次比赛前排序确定 ...

  7. 洛谷 - P1309 - 瑞士轮 - 归并排序

    https://www.luogu.org/problemnew/show/P1309 一开始写的直接快排没想到真的TLE了. 想到每次比赛每个人前移的量不会很多,但是不知从哪里开始优化. 搜索一下原 ...

  8. 洛谷 P1309 瑞士轮 题解

    每日一题 day4 打卡 Analysis 暴力+快排(其实是归并排序) 一开始天真的以为sort能过,结果光荣TLE,由于每次只更改相邻的元素,于是善于处理随机数的快排就会浪费很多时间.于是就想到归 ...

  9. 洛谷P1309 瑞士轮——题解

    题目传送 思路非常简单,只要开始时把结构体排个序,每次给赢的加分再排序,共r次,最后再输出分数第q大的就行了. (天真的我估错时间复杂度用每次用sort暴力排序结果60分...)实际上这道题估算时间复 ...

  10. P1309 瑞士轮 (吸氧了)

    P1309 瑞士轮 题解 1.这题可以模拟一下 2.sort吸氧可以过(可能是排序有点慢吧,不开会T) sort排序时注意: return 1 是满足条件,不交换 return 0是不满足,交换 代码 ...

随机推荐

  1. NOIP2019(CSP2019) 游记

    NOIP2019(CSP2019) 游记 近一年的似乎也就是感觉比别的学校的同学水平低的不止一点,到现在也没有搞清楚大概应该怎么科学有效的练习,并不会思考"为什么想不到"和&quo ...

  2. Intraweb IIS发布,数据连接问题

    日前,用IW做了小东西,开始用单独的执行程序发布,一切都没有什么问题,但是发布到正式环境中,用windows IIS发布,怎么也获取不了程序所在的物理路径,而后看了万一的博客,试了一下程序能正常运行, ...

  3. IO流,字节流复制文件,字符流+缓冲复制文件

    JAVAIO如果按流向分:输入流和输出流两种 输入流的基类:InputStream   Reader 输出流的基类:OutputStream   Writer 如果按数据单元划分:字节流和字符流 字节 ...

  4. Linux学习-LVS跨网段DR模型和FWM多服务绑定

    一.实验环境 系统:CentOS7.6 主机:5台 (虚拟机) 客户端1台:172.16.236.134/24 (NAT网卡),网关指向 172.16.236.185/24(路由服务器) 路由服务器1 ...

  5. RN组件的生命周期

    来自:http://www.devio.org/tags/#React%20Native

  6. HDU - 5306 Gorgeous Sequence 线段树 + 均摊分析

    Code: #include<algorithm> #include<cstdio> #include<cstring> #define ll long long ...

  7. HDU 4027 Can you answer these queries? (线段树成段更新 && 开根操作 && 规律)

    题意 : 给你N个数以及M个操作,操作分两类,第一种输入 "0 l r" 表示将区间[l,r]里的每个数都开根号.第二种输入"1 l r",表示查询区间[l,r ...

  8. Acvitivi网关(十一)

    1排他网关 1.1 什么是排他网关 排他网关(也叫异或(XOR)网关,或叫基于数据的排他网关),用来在流程中实现决策. 当流程执行到这个网关,所有分支都会判断条件是否为 true,如果为 true 则 ...

  9. SQL的一对多,多对一,一对一,多对多什么意思?

    1.一对多:比如说一个班级有很多学生,可是这个班级只有一个班主任.在这个班级中随便找一个人,就会知道他们的班主任是谁:知道了这个班主任就会知道有哪几个学生.这里班主任和学生的关系就是一对多. 2.多对 ...

  10. RabbitMQ + Springboot +“Hello Word”

    https://www.rabbitmq.com/getstarted.html 官网文档 我们将呼叫我们的消息发布者(发送者)发送和我们的消息消费者(接收者) Recv.发布者将连接到RabbitM ...