T1.淘汰赛制

比赛时的淘汰赛制,给出每两个球队比赛的胜率,求出最终胜率最高的队伍。

这题的概率真的很难算啊感觉。。。一开始打的代码打下来就是用f[i][j]表示i场比赛后第j人还在场的概率。不难看出这是一棵树形的状态树

那么可以看出,每次比较的区间长度是2n,那么可以通过枚举左端点来确定区间。确定区间后,f[i][j]=f[i-1][j]*sum(f[i-1][k]*a[j][k])

T2.种树(trees)

有长度为n的区间,有h个要求,每个要求为[b,e]内至少标记t个数,求最少标记数。

贪心吧。。。

一种做法是先把区间按e,b排序,然后先满足e小的需求,尽量往e靠,每次先计算此区间内已被标记的,然后标记未被标记的直到满足条件,最后扫一遍计算被标记的数;

另一种做法是类似的,每次标记后,搜索后面的区间,如果当前标记点在那个区间内,则减少那个区间的要求量,重复动作直到当前区间需求减少为0。每次检查新区间的时候就把要求量加入ans,最后输出ans即可。

由于第一个做法较简单,第二个较难描述,所以放一下第二种做法的代码。

  1. #include <iostream>
  2.  
  3. #include <cstdio>
  4.  
  5. #include <algorithm>
  6.  
  7. using namespace std;
  8.  
  9. struct request
  10.  
  11. {
  12.  
  13. int b,e,t;
  14.  
  15. bool operator < (const request &xx) const
  16.  
  17. {
  18.  
  19. return e==xx.e?b<xx.b:e<xx.e;
  20.  
  21. }
  22.  
  23. }q[];
  24.  
  25. int n,h;
  26.  
  27. int v[];
  28.  
  29. int main()
  30.  
  31. {
  32.  
  33. freopen("trees.in","r",stdin);
  34.  
  35. freopen("trees.out","w",stdout);
  36.  
  37. cin >> n;
  38.  
  39. cin >> h;
  40.  
  41. for (int i=;i<=h;i++)
  42.  
  43. {
  44.  
  45. cin >> q[i].b >> q[i].e >> q[i].t;
  46.  
  47. }
  48.  
  49. sort(q+,q+h+);
  50.  
  51. int cnt=;
  52.  
  53. for (int i=;i<=h;i++)
  54.  
  55. {
  56.  
  57. if (q[i].t>)
  58.  
  59. {
  60.  
  61. int pos=q[i].e;
  62.  
  63. cnt+=q[i].t;
  64.  
  65. for (int j=;j<=q[i].t;j++)
  66.  
  67. {
  68.  
  69. while (v[pos])
  70.  
  71. pos--;
  72.  
  73. v[pos]=;
  74.  
  75. for (int k=i+;k<=h;k++)
  76.  
  77. if (q[k].b<=pos&&pos<=q[k].e)
  78.  
  79. q[k].t--;
  80.  
  81. }
  82.  
  83. }
  84.  
  85. }
  86.  
  87. cout << cnt << "\n";
  88.  
  89. }

T3.软件开发(software)

有两个项目各有m个步骤,由n个人来完成,每个人完成同一任务的一个步骤时间不变,求出完成的最少时间。(题目给出了每个人完成这两个任务的时间)

一看感觉题目有点熟悉,然后就开始dp。一开始的状态是f[i][j][k],表示前i个人完成第一个任务的j个步骤,第二个任务的k个步骤所需的最短时间。打了五重循环然后发现是错的,因为每个人的效率是不同的。所以没有交,换了一种打法。

先二分时间,然后就是判断这个时间下是否可行了。判断也是一个dp的过程,f[i][j]表示前i个人做了第一个任务的j个步骤时,还能做第二个任务的步骤数。f[i][j]=max(f[i][j],f[i-1][k]+(t-(j-k)*d1[i])/d2[i])

(d1[i],d2[i]分别表示第i个人做两个任务的一个步骤的时间)。如果最后f[n][m]>=m就表示可行。

如此就能AC了。

(但是第一遍为什么只有40分呢?这就和我当时处理f[1][j]的时候不谨慎有很大关系了,还有一处错就是我把j*d1[i]>t的情况全部舍去了,就把一些情况漏掉了。。。)

二模02day1解题报告的更多相关文章

  1. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  2. 二模14day1解题报告

    注:Index数☞由4,7组成的十进制数. T1.全排列(permutation) 求n个数的第k个排列中,有多少个Index位置上是Index数. 由于k的范围比较小,n的范围比较大(都是109), ...

  3. 二模12day2解题报告

    T1.笨笨玩糖果(sugar) 有n颗糖,两个人轮流取质数颗糖,先取不了的(0或1)为输,求先手能否必胜,能,输出最少几步肯定能赢:不能,输出-1. 一开始天真的写了一个dp,f[i]表示i颗糖最少取 ...

  4. 二模01day1解题报告

    T1.音量调节(changingsounds) 有n个物品的背包(有点不一样,每个物品必须取),给出初始价值,物品价值可正可负(就是两种选择嘛),求可能的最大价值,不可能(<0或>maxs ...

  5. 二模15day1解题报告

    T1.合并序列(minval) 给出长为 n的AB两个序列求两两相加中最小的n个. 据说有证明(在蓝书上,优先队列部分)先把A[1~n]+b[1]入队,然后每取一个a[x]+b[y]就把a[x]+b[ ...

  6. 二模14day2解题报告

    T1.砍树(cuttree) 给出n棵树,要锯下m米木材,现在有一个高度h,h以上所有木头都砍下来,求满足m米的最小h 很简单的二分答案判断可行性. T2.快速求和(quicksum) 给出数字串s, ...

  7. 二模12day1解题报告

    T1.笨笨与电影票(ticket) 有n个1和m个0,求每个数前1的个数都大于等于0的个数的排列数. 非常坑的一道题,推导过程很烦.首先求出所有排列数是 C(n+m,m),然后算不合法的个数. 假设存 ...

  8. 二模07day1解题报告

    T1.种树(tree) 有n棵树,各有高度,要求每棵树的高度都小于它到其他树的距离(可能种一起).求砍掉的总高度是多少. Ok,那么可以想到,只要满足每棵树和最近的树满足条件就可以保证和其他树满足了. ...

  9. 二模07day2解题报告

    T1.采药(medic) 有n个草药,要在m的时间内获得最大价值. 乍一看像是01背包,然而数据只能过50分. 考虑数据范围,t<=10,w<=10,所以只有121种草药.考虑多重背包的二 ...

随机推荐

  1. Python的平凡之路(6)

    一.面向对象编程介绍 1 编程范式:          编程范式(Programming Paradigm)是某种编程语言典型的编程风格或者说是编程方式.随着编程方法学和软件工程研究的深入,特别是OO ...

  2. ViewHolder简洁写法

    ViewHolder holder = null;         if(convertView == null){                 convertView = mInflater.i ...

  3. [深入Python]Python的私有变量

    Python没有真正的私有变量.内部实现上,是将私有变量进程了转化,规则是:_<类名><私有变量> 下面的小技巧可以获取私有变量: class Test(object): de ...

  4. BZOJ 3670 && BZOJ 3620 && BZOJ 3942 KMP

    最近感到KMP不会啊,以前都是背板的现在要理解了. #include <iostream> #include <cstring> #include <cstdio> ...

  5. OD调试篇6--对一些真正的小程序进行一点点的修改

    先打开这个程序看看,提醒你这是一个未注册版本的软件.会发现只能添加4个联系人,这显然是我不想看见的,于是我要对这个程序进行一些修改,嘿嘿... 通过OD载入这个程序 有一些(SEH)也就是异常,我们可 ...

  6. NIC bonding

    Bonding is the same as port trunking. In the following I will use the word bonding because practical ...

  7. [原创] 用两个queue实现stack的功能

    #include <iostream> #include <queue> using namespace std; template <class T> class ...

  8. LeetCode() Min Stack 不知道哪里不对,留待。

    class MinStack { public: MinStack() { coll.resize(2); } void push(int x) { if(index == coll.size()-1 ...

  9. 【转载】基于ANSYS APDL的有裂纹平板问题的断裂力学仿真(PLANE183)

    原文地址:http://blog.sina.com.cn/s/blog_9e19c10b0102vnw7.html 对于一般的强度问题,我们总是用应力来度量其强度的.但是对于有裂纹的,高强度的构件,使 ...

  10. SQL Server使用convert对datetime日期数据进行获取

    来源:http://database.51cto.com/art/201007/211883.htm 备注:本文的语法讲解确实是比较乱,似乎格式不太严谨.参考时还是以实例验证为准比较好 以下的文章主要 ...