分析:比较难想的一道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模拟赛 补兵的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  3. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  4. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  5. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  6. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  7. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  8. CH Round #58 - OrzCC杯noip模拟赛day2

    A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...

  9. CH Round #52 - Thinking Bear #1 (NOIP模拟赛)

    A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...

随机推荐

  1. Android最简单的实例 :环境搭建及HelloWorld

    Android开发之旅:环境搭建及HelloWorld 2010-04-12 00:45 by 吴秦, 883961 阅读, 140 评论, 收藏,  编辑 ——工欲善其事必先利其器 引言 本系列适合 ...

  2. [转]ASP.NET MVC 3 Application Upgrader

    本文转自:http://aspnet.codeplex.com/releases/view/59008 Recommended Download      ASP.NET MVC 3 Applicat ...

  3. AJPFX关于java数组排序

    /**         *将数组中的两个指定下标的元素交换位置                   *@param arr 要交换元素的数组引用地址值         *@param a 数组索引  ...

  4. Node.js——body方式提交数据

    引入核心模块 http,利用其 api(http.createServer) 返回一个 http.server 实例,这个实例是继承于net.Server,net.Server 也是通过net.cre ...

  5. Farseer.net轻量级开源框架 中级篇:UrlRewriter 地址重写

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: Cookies.Session.Request 下一篇:Farseer.net轻量 ...

  6. 浅谈CSS中的定位知识

    1,静态定位(static) 表示按照正常定位方案,元素盒按照在文档流中出现的顺序依次格式化: 2,相对定位(relative) 将移动元素盒,但是它在文档流中的原始空间会保留下来: 相对定位元素有如 ...

  7. list map接口传递

    1.传参时可以设置为jsonArray的格式 JSONArray array = new JSONArray(); JSONObject json = new JSONObject(); json.p ...

  8. 恩智浦Freescale Cortex-A9 迅为IMX6开发板平台初体验

    iTOP-i.MX6 开发板预装 Android4.4 系统,采用 9.7 寸(或者 7 寸或者 4.3 寸)IPS 屏 幕,至少 5 点以上触控,操作流畅,无论是高清视频.游戏等都会有上佳的表现,实 ...

  9. struts2 针对类型转换出错的处理

    在类型转换出错时,需要在页面上显示友好提示: 类型转换出错时,会抛出一个运行时异常,程序会根据建立的属性文件,显示相应的错误提示. 实现方法: 1)新建局部属性文件或者全局属性文件 局部属性文件:放置 ...

  10. anchor_target_layer层解读

    总结下来,用generate_anchors产生多种坐标变换,这种坐标变换由scale和ratio来,相当于提前计算好.anchor_target_layer先计算的是从feature map映射到原 ...