noip模拟赛 补兵
分析:比较难想的一道dp题.要想补兵的数量最多,最后每个小兵的血量肯定是呈一个阶梯状的:i,i+1,i+2......i+k.那么记录一下每个血量i离它最近的小兵的血量是多少,记作cur[i].那么把这个小兵砍成i就需要砍cur[i] - i次,显然一轮是不可能有这么多次的,只有前面的血量不去砍,留到i才有可能有砍这么多次.
那么状态就设计为f[i][j]表示砍到了血量为i的小兵,还剩j次刀能继续砍的最大补兵数.这么设计状态的思路就是如果只用一个f[i]来记录状态的话,不知道能否达到这个状态,可能我把cur[i]砍到i之后,i-1就已经被砍死了,所以我要看前一个i-1能留多少刀给i去砍,对于i,可以将cur[i]的小兵砍成i,也可以不砍,如果不砍,那么f[i][j] = f[i-1][j-1],因为没砍,所以多了一次操作次数.如果砍的话,f[i][j] = max{f[i][j],f[i-1][j + cur[i] - i] + 1},cur[i]这个兵的血量可以变成i了,那么这个兵就能被补了,之前留的刀数就是j+cur[i]-i.不过j是有范围限制的,j<=i,因为血量i的小兵最多i次就会被老鹿砍死,最多只有i次机会,同样的,j+cur[i]-i <= i-1,因为是i-1留下的次数嘛.大致的原理就是将所有小兵的血量尽可能地变成需要的阶梯状,每次留下来的次数就留给下一次砍.
挺难想到的.还是有一点贪心的思想,先要想出什么样的局面是最优的,再用dp来求怎么要到这样的局面.
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm> using namespace std; int T, n, a[], ans, f[][], maxn,sta[], cur[], top, cnt[]; int main()
{
scanf("%d", &T);
while (T--)
{
memset(sta, , sizeof(sta));
memset(f, , sizeof(f));
top = ;
ans = ;
memset(cur, , sizeof(cur));
memset(cnt, , sizeof(cnt));
scanf("%d", &n);
for (int i = ; i <= n; i++)
{
scanf("%d", &a[i]);
cnt[a[i]]++;
maxn = max(maxn, a[i]);
}
for (int i = ; i <= maxn; i++)
{
if (cnt[i] == )
sta[++top] = i;
else
{
while (cnt[i] > && top > )
{
cur[sta[top--]] = i;
cnt[i]--;
}
cur[i] = i;
}
}
for (int i = ; i <= maxn; i++)
for (int j = ; j <= i; j++)
{
if (j > )
f[i][j] = f[i - ][j - ];
if (cur[i] != && j + cur[i] - i <= i - )
f[i][j] = max(f[i][j], f[i - ][j + cur[i] - i] + );
ans = max(ans, f[i][j]);
}
printf("%d\n", ans);
} return ;
}
noip模拟赛 补兵的更多相关文章
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程
数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...
- 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...
- 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...
- 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...
- CH Round #58 - OrzCC杯noip模拟赛day2
A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...
- CH Round #52 - Thinking Bear #1 (NOIP模拟赛)
A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...
随机推荐
- Android最简单的实例 :环境搭建及HelloWorld
Android开发之旅:环境搭建及HelloWorld 2010-04-12 00:45 by 吴秦, 883961 阅读, 140 评论, 收藏, 编辑 ——工欲善其事必先利其器 引言 本系列适合 ...
- [转]ASP.NET MVC 3 Application Upgrader
本文转自:http://aspnet.codeplex.com/releases/view/59008 Recommended Download ASP.NET MVC 3 Applicat ...
- AJPFX关于java数组排序
/** *将数组中的两个指定下标的元素交换位置 *@param arr 要交换元素的数组引用地址值 *@param a 数组索引 ...
- Node.js——body方式提交数据
引入核心模块 http,利用其 api(http.createServer) 返回一个 http.server 实例,这个实例是继承于net.Server,net.Server 也是通过net.cre ...
- Farseer.net轻量级开源框架 中级篇:UrlRewriter 地址重写
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: Cookies.Session.Request 下一篇:Farseer.net轻量 ...
- 浅谈CSS中的定位知识
1,静态定位(static) 表示按照正常定位方案,元素盒按照在文档流中出现的顺序依次格式化: 2,相对定位(relative) 将移动元素盒,但是它在文档流中的原始空间会保留下来: 相对定位元素有如 ...
- list map接口传递
1.传参时可以设置为jsonArray的格式 JSONArray array = new JSONArray(); JSONObject json = new JSONObject(); json.p ...
- 恩智浦Freescale Cortex-A9 迅为IMX6开发板平台初体验
iTOP-i.MX6 开发板预装 Android4.4 系统,采用 9.7 寸(或者 7 寸或者 4.3 寸)IPS 屏 幕,至少 5 点以上触控,操作流畅,无论是高清视频.游戏等都会有上佳的表现,实 ...
- struts2 针对类型转换出错的处理
在类型转换出错时,需要在页面上显示友好提示: 类型转换出错时,会抛出一个运行时异常,程序会根据建立的属性文件,显示相应的错误提示. 实现方法: 1)新建局部属性文件或者全局属性文件 局部属性文件:放置 ...
- anchor_target_layer层解读
总结下来,用generate_anchors产生多种坐标变换,这种坐标变换由scale和ratio来,相当于提前计算好.anchor_target_layer先计算的是从feature map映射到原 ...