【问题描述】

(注:此题为d2t2-难度)

田忌又在跟大王van赛马的游戏

田忌与大王一共有2n匹马,每个马都有一个能力值x,1<=x<=2n且每匹马的x互不相同。每次田忌与大王放出一匹马,较大的获胜。但是田忌有一个能力,在任何比赛的开始前,他可以把马变成x较小的获胜,并一直持续到比赛结束

田忌可以一直不用这个能力,也可以在第一轮前使用

现在,田忌已经知道了大王的出马顺序,田忌要问聪明的你,他最多能获得几次胜利?

【输入格式】

第一行为一个整数:N(1<=N<=50000)接下来 一行n个数,为大王的顺序出场的n匹马的能力值(田忌的马可以通过此求出)

【输出格式】

一个整数,表示最多的获胜次数

【样例输入】

4

1

8

4

3

【样例输出】

3

【样例说明】

田忌第一次出能力为7的马获胜

第二次开始前使用能力,出能力为6的马获胜

第三次出能力为5的马失败

第四次出能力为2的马获胜

总共3次

【出题人的关怀】

乱搞出奇迹(雾)

大胆猜想,不要证明

【数据规模】

对于20%的数据,n<=10

对于40%的数据 n<=20

对于35%的数据,不使用能力也可获得最多胜利(即20个点中有7个点不使用能力的程序能过(雾))

前3个档的总分为60分(出题人的关怀)

对于80%的数据,n<=5000

对于100%的数据,n<=50000,

【一些帮助】

大样例

一些帮助

题解

先贴一下出题人yk神犇的题解

另外这位大佬在洛谷上也发了题解

接下来是蒟蒻的题解:

首先,回顾田忌赛马,我们发现tj是每次出比大王稍微快一些的马(如果有的话)。那么如果tj用了技能,他显然应该出比大王稍微慢一些的马。于是我们就可以很容易知道tj不用技能或是刚开始就用技能的最佳方案。

我们令\(f[i]\)表示前\(i\)个每次都出比对方稍微大一点的牌,最多能赢几次;\(g[i]\)表示从\([i,n]\)中每次出比对方稍微小一点的牌,最多赢几次。

我们自然想到\(ans = max(f[i]+g[i+1]\mid i\in [0,n])\),但这样显然是有重复的。

那么这样真的不可行吗?让我们冷静分析一下:

如图,对于一个\(i\),如果有一匹马\(mid\)被选了两次:\(f\)数组对\(l\),\(g\)数组对\(r\)。那么必定有一匹马没被\(f\)与\(g\)用过(多出来了),设其能力值为\(t\)。显然,\(t\notin[l,r]\)(不符合贪心规则)。不管这匹马在\(l\)左侧或是\(r\)的右侧,结果都是相同的。所以其实这个贪心思路是正确的。

代码

#include <cstdio>
#include <cctype>
#include <set> using namespace std; const int maxn = 50005; int f[maxn], g[maxn];
int n; #define dd c = getchar()
inline int read(int& x)
{
x = 0;
char dd;
bool f = false;
for(; !isdigit(c); dd)
{
if(c == '-')
f = true;
if(c == EOF)
return EOF;
}
for(; isdigit(c); dd)
x = (x<<1) + (x<<3) + (c^48);
if(f) x = -x;
return 1;
}
#undef dd set<int> zheng, fan;
set<int>::iterator z; int dw[maxn];
bool whose[maxn<<1]; inline void get()
{
read(n);
for(int i = 1; i <= n; ++i)
{
read(dw[i]);
whose[dw[i]] = true;
}
for(int i = 1; i <= (n<<1); ++i)
{
if(!whose[i])
{
zheng.insert(i);
fan.insert((n<<1)-i);
}
}
} int main()
{
freopen("horse.in", "r", stdin);
freopen("horse.out", "w", stdout);
get();
for(int i = 1; i <= n; ++i)
{
z = zheng.upper_bound(dw[i]);
if(z != zheng.end())
{
f[i] = f[i-1] + 1;
zheng.erase(z);
}
else
f[i] = f[i-1];
}
for(int i = n; i >= 1; --i)
{
z = fan.upper_bound((n<<1)-dw[i]);
if(z != fan.end())
{
g[i] = g[i+1] + 1;
fan.erase(z);
}
else
g[i] = g[i+1];
}
int ans = 0;
for(int i = 0; i <= n; ++i)//注意从0开始,可以不用技能
ans = max(ans, f[i]+g[i+1]);
printf("%d", ans);
return 0;
}

20180527模拟赛T1——新田忌赛马的更多相关文章

  1. 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解

    今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...

  2. 20180610模拟赛T1——脱离地牢

    Description 在一个神秘的国度里,年轻的王子Paris与美丽的公主Helen在一起过着幸福的生活.他们都随身带有一块带磁性的阴阳魔法石,身居地狱的魔王Satan早就想着得到这两块石头了,只要 ...

  3. NOIP欢乐模拟赛 T1 解题报告

    小澳的方阵 (matrix.cpp/c/pas) [题目描述] 小澳最近迷上了考古,他发现秦始皇的兵马俑布局十分有特点,热爱钻研的小澳打算在电脑上还原这个伟大的布局. 他努力钻研,发现秦始皇布置兵马俑 ...

  4. [模拟赛] T1 高级打字机

    Description 早苗入手了最新的高级打字机.最新款自然有着与以往不同的功能,那就是它具备撤销功能,厉害吧. 请为这种高级打字机设计一个程序,支持如下3种操作: 1.T x:在文章末尾打下一个小 ...

  5. 2019.2.25 模拟赛T1【集训队作业2018】小Z的礼物

    T1: [集训队作业2018]小Z的礼物 我们发现我们要求的是覆盖所有集合里的元素的期望时间. 设\(t_{i,j}\)表示第一次覆盖第i行第j列的格子的时间,我们要求的是\(max\{ALL\}\) ...

  6. [NOIP2018校模拟赛]T1 阶乘

    题目: 描述 有n个正整数a[i],设它们乘积为p,你可以给p乘上一个正整数q,使p*q刚好为正整数m的阶乘,求m的最小值. 输入 共两行. 第一行一个正整数n. 第二行n个正整数a[i]. 输出 共 ...

  7. [NOIP2018校模拟赛]T1聚会 party

    题目链接: 聚会 分析: 设每个点到1号点的距离为dist_{i},每个点的权值为x_{i},目标点到1号点的距离为dist,权值为x,那么对于每一次查询,我们讨论三种情况: ① 目标家庭在区间左边( ...

  8. 【2019.8.15 慈溪模拟赛 T1】插头(plugin)(二分+贪心)

    二分 首先,可以发现,最后的答案显然满足可二分性,因此我们可以二分答案. 然后,我们只要贪心,就可以验证了. 贪心 不难发现,肯定会优先选择能提供更多插座的排插,且在确定充电器个数的情况下,肯定选择能 ...

  9. 【2019.7.20 NOIP模拟赛 T1】A(A)(暴搜)

    打表+暴搜 这道题目,显然是需要打表的,不过打表的方式可以有很多. 我是打了两个表,分别表示每个数字所需的火柴棒根数以及从一个数字到另一个数字,除了需要去除或加入的火柴棒外,至少需要几根火柴棒. 然后 ...

随机推荐

  1. 《Linux就该这么学》培训笔记_ch12_使用Samba或NFS实现文件共享

    <Linux就该这么学>培训笔记_ch12_使用Samba或NFS实现文件共享 文章最后会post上书本的笔记照片. 文章主要内容: SAMBA文件共享服务 配置共享资源 Windows挂 ...

  2. POJ-最大连续子序列和

    给定一个整数序列,找到一个具有最大和的连续子序列(子序列最少包含一个元素),返回其最大和. 实例输入: -2, 1, -3, 4, -1, 2, 1, -5, 4 实例输出: 6(连续子序列4, -1 ...

  3. Python3+WebSockets实现WebSocket通信

    一.说明 1.1 背景说明 前段时间同事说云平台通信使用了个websocket的东西,今天抽空来看一下具体是怎么个通信过程. 从形式上看,websocket是一个应用层协议,socket是数据链路层. ...

  4. 封装:Cmd命令调用和常用命令

    原文:封装:Cmd命令调用和常用命令 一.Cmd命令调用方法 1.静态方法调用 class Program { static void Main(string[] args) { // Todo :打 ...

  5. 使用ASP.NET Core MVC应用程序中的ResponseCache属性处理缓存(转载)

    HTTP响应的缓存意味着当发出HTTP请求时,服务器生成的响应由浏览器或服务器存储在某个地方,以便在对同一资源的连续HTTP请求中重复使用.实质上,我们正在存储生成的响应,并将该响应重用于后续请求一段 ...

  6. intent 和 Broadcast Receiver之间的通信

    工作原理是通过封装一个service启动的一个线程产生的随机数封装到intent对象传递给Activity,Activity接受到后讲结果输出到屏幕. java的代码: package jm.out; ...

  7. 2019 荔枝java面试笔试题 (含面试题解析)

      本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.荔枝等公司offer,岗位是Java后端开发,因为发展原因最终选择去了荔枝,入职一年时间了,也成为了面试官,之 ...

  8. JavaScript 事件(基础)

    一.事件 事件:触发-响应机制. 二.事件三要素 1.事件源:触发事件的元素 2.事件名称:发送了什么方式的事件 3.事件处理程序:事件触发后要执行的代码(函数形式) 三.事件的使用方式 1.获取元素 ...

  9. 汽车行业如何个性化定制转型?看APS系统在这家企业的运用

    传统汽车行业中往往采用的是按库存推动式生产,一旦市场产生变动就会造成大量的生产,给企业带来大批的资金压力,而另一方面采用按单生产的方式企业往往面临供应链,产能的诸多约束条件限制,稍有不慎就会带来产线停 ...

  10. Android SDK版本号与API Level 的对应关系及发布时间(更新到28)

    Android SDK版本号与API Level 的对应关系及发布时间 平台版本号 API 级别 VERSION_CODE(代号) 发布时间 Android 9.0 28 Pie/P(馅饼) 2018 ...