题目链接:http://codeforces.com/submissions/ywindysai

题目意思:有 n 朵花,每朵花都有一定的高度(第 i 朵花对应 ai),m 天之后要把这些花送给别人。不过这 m 天里可以通过淋花来让花长得尽可能高啦(当然不希望把长得矮矮的花送给人啦),每天只能淋一次,一次覆盖的范围是连续的 w 朵,淋完水后被淋的花会在当天长高 1 个单位(one height unit)。现在就问,m天之后,最矮的那朵花最高能长到多高。

首先,我对这条题目完全没有想法,四个字:无从下手!好啦,直接看题解,英文太差,有些地方看不懂,直接看代码,还是有点不懂,手动模拟终于明白了^_^

总体的思路就是:二分找出这个高度!(姑且说它为期望值X)。计算出这 n 朵花是否每朵都能够在这 m 天内长到X 那么高。怎么找是一个关键。假设花从左到右是从0~n-1编号的。

对于每个期望值X(二分,使得即使X好大,也只是O(log2N),N 最大为1e14(10^5 × 10^9)),我们都要按顺序遍历这 n 朵花(在我看来,按顺序来做确实可以化繁为简,将问题简单化)。首先对于前 w 多花,它们都不能借助前面花的淋水次数来减少它们被淋的次数(通过段来减少,就是w 啦),因为它们是最先嘛。那么第一朵花得到期望值X要淋X-a[0] 天了,而接下来连续的w-1朵就可以少淋 X-a[0] 这么多天了,而且这w-1朵可以在原来的高度下长高X-a[0] 的高度。不过w-1朵之后的花就不能依靠第一朵花被淋的次数了(只能覆盖w段),不过对于 i (i >= w)的每朵花,它可以依靠i-1, i-2,...,i-w 朵花被淋的次数来长高相应高度,这样往往可以使得当第 i 朵花要到达期望值时的淋水天数少于它本来最多要淋的次数(X - a[i])

 #include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <vector>
using namespace std; typedef long long ll;
const ll maxn = 1e14; vector<ll> a;
ll m, w, n; bool check(ll x)
{
ll move = ;
ll scur = ;
vector<ll> s(n+, ); // s 的 n+1个元素初始值都为0
for (ll i = ; i < n; i++)
{
scur -= (i >= w ? s[i-w] : ); // 刚开始的w-1朵花不能依靠前面花的被淋天数来增高,之后的都可以
if (x > a[i] + scur)
{
s[i] = x - scur- a[i]; // 第i朵花要达到x实际还需要x-scur-a[i]这么多天
scur += s[i]; // 更新次数,之后的w-1朵花可以减少淋scur那么多天
move += s[i]; // 累积天数
}
if (move > m)
return false;
}
return true; // move <= m
} int main()
{
while (scanf("%lld%lld%lld", &n, &m, &w) != EOF)
{
a.resize(n+); // 设 a 的 size和capacity 为 n+1(其实n也可以)
for (int i = ; i < n; i++)
scanf("%lld", &a[i]);
ll left = , right = maxn;
ll X = ;
while (left <= right) // < 是错的,一定是 <=
{
ll mid = (left+right) >> ;
if (check(mid)) // 代表每朵花都可以在 m 天内达到mid的高度
{
X = mid;
left = mid + ;
}
else
right = mid - ;
}
printf("%lld\n", X);
}
return ;
}

题解说线段树也能做

http://codeforces.ru/blog/entry/13465?locale=en

总的来说,C题都是比较考思维滴!!!

codeforces 460C. Present 解题报告的更多相关文章

  1. codeforces B. New Year Present 解题报告

    题目链接:http://codeforces.com/contest/379/problem/B 题目意思:给定一个有n个钱包的序列,其中第i个钱包需要投入ai个钱币,需要编写一个程序,使得在对第i个 ...

  2. Codeforces Round #300 解题报告

    呜呜周日的时候手感一直很好 代码一般都是一遍过编译一遍过样例 做CF的时候前三题也都是一遍过Pretest没想着去检查... 期间姐姐提醒说有Announcement也自信不去看 呜呜然后就FST了 ...

  3. codeforces 31C Schedule 解题报告

    题目链接:http://codeforces.com/problemset/problem/31/C 题目意思:给出 n 个 lessons 你,每个lesson 有对应的 起始和结束时间.问通过删除 ...

  4. codeforces 499B.Lecture 解题报告

    题目链接:http://codeforces.com/problemset/problem/499/B 题目意思:给出两种语言下 m 个单词表(word1, word2)的一一对应,以及 profes ...

  5. codeforces 495C. Treasure 解题报告

    题目链接:http://codeforces.com/problemset/problem/495/C 题目意思:给出一串只有三种字符( ')','(' 和 '#')组成的字符串,每个位置的这个字符 ...

  6. codeforces 490B.Queue 解题报告

    题目链接:http://codeforces.com/problemset/problem/490/B 题目意思:给出每个人 i 站在他前面的人的编号 ai 和后面的人的编号 bi.注意,排在第一个位 ...

  7. CodeForces 166E -Tetrahedron解题报告

    这是本人写的第一次博客,学了半年的基础C语言,初学算法,若有错误还请指正. 题目链接:http://codeforces.com/contest/166/problem/E E. Tetrahedro ...

  8. codeforces 489A.SwapSort 解题报告

    题目链接:http://codeforces.com/problemset/problem/489/A 题目意思:给出一个 n 个无序的序列,问能通过两两交换,需要多少次使得整个序列最终呈现非递减形式 ...

  9. codeforces 485A.Factory 解题报告

    题目链接:http://codeforces.com/problemset/problem/485/A 题目意思:给出 a 和 m,a 表示第一日的details,要求该日结束时要多生产 a mod ...

随机推荐

  1. git学习五:eclipse使用git下载项目

    原文:http://blog.csdn.net/u014079773/article/details/51597213 准备工作: 目的:从远程仓库github上down所需的项目 eclipse使用 ...

  2. iOS -- SKScene类

      SKScene类 继承自 SKEffectNode:SKNode:UIResponder:NSObject 符合 NSCoding(SKNode)NSCopying(SKNode)NSObject ...

  3. Android图片加载神器之Fresco,基于各种使用场景的讲解

    Fresco是Facebook开源Android平台上一个强大的图片加载库,也是迄今为止Android平台上最强大的图片加载库. 优点:相对于其他开源的第三方图片加载库,Fresco拥有更好的内存管理 ...

  4. linux 和网络安装 linux

    接触linux 一年了,一直没有总结过什么东西.在开学前的这么几天把之前做的一些东西重新整理一下吧. 或许还会有别的收获呢. linux安装: 去年10月份接触linux以来安装不下数十次,不管是光盘 ...

  5. linux的history命令设置

    history的历史记录,同一个用户的各个会话,读取到的内容也是不一样的,原因是它读取的是shell会话缓存里的内容.只有当用户退出当前会话的时候,会话里的缓存内容才会写入~/.bash_histor ...

  6. 5.【nuxt起步】-swiper组件

    接下来是一个比较常用,也比较重要的组件 swiper,可以自行搜索 vue swiper,有很多开源组件,我这里就复用之前一个熟悉的, 1.新建component/banner.vue 刷新报错: 要 ...

  7. hdu5379||2015多校联合第7场1011 树形统计

    pid=5379">http://acm.hdu.edu.cn/showproblem.php? pid=5379 Problem Description Little sun is ...

  8. LattePanda 之深入学习 Firmata通讯

    前言 原创文章,转载引用务必注明链接,水平有限,如有疏漏,欢迎指正. 本文使用Markdown写成,为获得更好的阅读体验和正常的链接.图片显示,请访问我的博客原文: http://www.cnblog ...

  9. java性能监控工具jcmd-windows

    jcmd Sends diagnostic command requests to a running Java Virtual Machine (JVM). Synopsis jcmd [-l|-h ...

  10. Git命令学习总结(-)

    入职的第一天,让git命令直接给难住了,汗!使用习惯可视化的工具对于命令行早就忘记的一干二净.还好,回家自己练习一下,总会没有错的.git就不做简介了,版本管理除了svn就是git了,其他的都无所谓了 ...