题目链接:

  https://vijos.org/p/1771

题目大意

  给定2N个人(N<=100 000)和其初始分数、能力值(能力两两不同),比赛M次(M<=50),每次PK都是按分数排序后第1和第2比,第3和第4比....能力高的获胜,问比M次后第Q个人是谁。

题目思路:

  【单调队列】

  略加思索,我们不难发现,每次比赛获胜的人和失败的人分别组成了两个按分数递减的队列。

  于是一开始快排一下,接着可以按照归并排序的思路,每次比完将获胜的人和失败的人合并。时间复杂度就降到O(N*M)了。

  (一开始就随手写了个快排m次的暴力程序,丢上去只有70分,只好好好写代码了)

  

  

  1. //
  2. //by coolxxx
  3. //
  4. #include<iostream>
  5. #include<algorithm>
  6. #include<string>
  7. #include<iomanip>
  8. #include<memory.h>
  9. #include<time.h>
  10. #include<stdio.h>
  11. #include<stdlib.h>
  12. #include<string.h>
  13. #include<stdbool.h>
  14. #include<math.h>
  15. #define min(a,b) ((a)<(b)?(a):(b))
  16. #define max(a,b) ((a)>(b)?(a):(b))
  17. #define abs(a) ((a)>0?(a):(-(a)))
  18. #define lowbit(a) (a&(-a))
  19. #define sqr(a) (a)*(a)
  20. #define swap(a,b) (a)^=(b),(b)^=(a),(a)^=(b)
  21. #define eps 1e-8
  22. #define MAX 0x7f7f7f7f
  23. #define INF 20000
  24. #define PI 3.1415926535897
  25. #define N 100004
  26. using namespace std;
  27. int n,m,lll,ans,cas;
  28. struct xxx
  29. {
  30. int num,s,p;
  31. }a[N<<],w[N],l[N];
  32. bool cmp(xxx aa,xxx bb)
  33. {
  34. if(aa.s!=bb.s)return aa.s>bb.s;
  35. return aa.num<bb.num;
  36. }
  37. int main()
  38. {
  39. #ifndef ONLINE_JUDGE
  40. // freopen("1.txt","r",stdin);
  41. // freopen("2.txt","w",stdout);
  42. #endif
  43. int i,j,k;
  44. while(~scanf("%d",&n) && n)
  45. {
  46. scanf("%d%d",&m,&cas);
  47. n<<=;
  48. for(i=;i<=n;i++)
  49. {
  50. a[i].num=i;
  51. scanf("%d",&a[i].s);
  52. }
  53. for(i=;i<=n;i++)
  54. scanf("%d",&a[i].p);
  55. sort(a+,a++n,cmp);
  56. w[(n>>)+].s=l[(n>>)+].s=-MAX;
  57. for(i=;i<=m;i++,lll=)
  58. {
  59. for(j=;j<=n;j+=)
  60. {
  61. if(a[j].p>a[j+].p)
  62. {
  63. a[j].s++;
  64. w[++lll]=a[j];
  65. l[lll]=a[j+];
  66. }
  67. else
  68. {
  69. a[j+].s++;
  70. w[++lll]=a[j+];
  71. l[lll]=a[j];
  72. }
  73. }
  74. for(j=,k=;j<=(n>>)+ && k<=(n>>)+;)
  75. if(w[j].s>l[k].s || (w[j].s==l[k].s && w[j].num<l[k].num))
  76. a[j+k-]=w[j++];
  77. else
  78. a[j+k-]=l[k++];
  79. }
  80. printf("%d\n",a[cas].num);
  81. }
  82. return ;
  83. }
  84.  
  85. /*
  86. //
  87.  
  88. //
  89. */

【单调队列】Vijos P1771 瑞士轮 (NOIP2011普及组第三题)的更多相关文章

  1. 【动态规划】Vijos P1104 采药(NOIP2005普及组第三题)

    题目链接: https://vijos.org/p/1104 题目大意: T时间,n个物品,每个耗时ti,可获得收益ci,求最大收益. 题目思路: [动态规划] 01背包裸题.一维二维都过了,放个一维 ...

  2. 【递归】Vijos P1114 FBI树(NOIP2004普及组第三题)

    题目链接: https://vijos.org/p/1114 题目大意: 把01串一分为二,左半边描述当前节点左子树,右半边描述右子树,子树全为1则为I节点,全为0则为B节点,混合则为F节点,直到当前 ...

  3. 【递归】Vijos P1132 求二叉树的先序序列(NOIP2001普及组第三题)

    题目链接: https://vijos.org/p/1132 题目大意: 给定二叉树的中序和后序遍历,求该二叉树先序遍历. 题目思路: [递归] 这题妥妥递归. 二叉树先序根左右,中序左根右,后序左右 ...

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

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

  5. NOIP2015普及组第四题推销员

    好久没有写博客了,今天再写一篇.还是先看题: 试题描述 阿明是一名推销员,他奉命到螺丝街推销他们公司的产品.螺丝街是一条死胡同,出口与入口是同一个,街道的一侧是围墙,另一侧是住户.螺丝街一共有 N 家 ...

  6. 【LOJ6067】【2017 山东一轮集训 Day3】第三题 FFT

    [LOJ6067][2017 山东一轮集训 Day3]第三题 FFT 题目大意 给你 \(n,b,c,d,e,a_0,a_1,\ldots,a_{n-1}\),定义 \[ \begin{align} ...

  7. NOIP2005普及组第4题 循环

    NOIP2005普及组第4题 循环 时间限制: 1 Sec  内存限制: 128 MB提交: 27  解决: 6[提交][状态][讨论版][命题人:外部导入] 题目描述 乐乐是一个聪明而又勤奋好学的孩 ...

  8. NOIP2005普及组第3题 采药 (背包问题)

    NOIP2005普及组第3题 采药 时间限制: 1 Sec  内存限制: 128 MB提交: 50  解决: 23[提交][状态][讨论版][命题人:外部导入] 题目描述 辰辰是个天资聪颖的孩子,他的 ...

  9. NOIP2008普及组第3题 传球游戏

    NOIP2008普及组第3题 传球游戏 时间限制: 1 Sec  内存限制: 128 MB提交: 29  解决: 16[提交][状态][讨论版][命题人:外部导入] 题目描述 上体育课的时候,小蛮的老 ...

随机推荐

  1. hadoop集群环境搭建之安装配置hadoop集群

    在安装hadoop集群之前,需要先进行zookeeper的安装,请参照hadoop集群环境搭建之zookeeper集群的安装部署 1 将hadoop安装包解压到 /itcast/  (如果没有这个目录 ...

  2. HttpClient使用cookie

    import java.io.IOException; import java.util.ArrayList; import java.util.List; import java.util.Map; ...

  3. javascript ~~ 符号的使用

    其实是一种利用符号进行的类型转换,转换成数字类型 大概是这样滴: ~~true == 1 ~~false == 0 ~~"" == 0 ~~[] == 0 ~~undefined ...

  4. P2P

    https://www.ppmoney.com/Withdraw http://www.daibang.com/

  5. HibernateTool的安装和使用(Eclipse中)

    http://blog.sina.com.cn/s/blog_919273e20101g1t7.html

  6. CI 笔记3 (easyui 的layout布局,最小化layout原型)

    在做easyui的layout的布局时,最小化一个原型,分2步,一个是div的父标签,一个是body做父标签,全屏的. 步骤分别为: 在设置的5个区中,div的最后一个,必须是data-options ...

  7. C#操作数据库,将其查查出来的记录条数显示在winform窗体中的方法之一

    //1.数据库链接的基本操作(略) //2.创建对象函数(关键部分) sqlConn.Open(); //初始化定义记录条数 ; object obj = sqlComm.ExecuteScalar( ...

  8. 十七、C# 反射、特性和动态编程

    反射.特性和动态编程   1.访问元数据 2.成员调用 3.泛型上的反射 4.自定义特性 5.特性构造器 6.具名参数 7.预定义特性 8.动态编程   特性(attribute)是在一个程序集中插入 ...

  9. pthread_setcanceltype 线程取消

    取消线程: (1)一个线程可以调用pthread_cancel来取消另一个线程.    (2)被取消的线程需要被join来释放资源.    (3)被取消的线程的返回值为PTHREAD_CANCELED ...

  10. SGU 144.Meeting

    题目: 两支地区ACM比赛的队伍决定为了国际决赛而在一起集训. 他们约定在某天的 X 时到 Y 时的某一时刻相会. 但由于他们很少按时到 (有的队伍比赛那天都会迟到), 他们没有设定一个确切的相遇时间 ...