田园将芜胡不归?既自以心为形役,奚惆怅而独悲?悟已往之不谏,知来者之可追。实迷途其未远,觉今是而昨非。

题目链接http://codeforces.com/contest/746/problem/F

cf div2 386,稍微纪念一下,终于变为blue,然而还是2道题的水平!先说一下这次的大体情况吧!这次是什么比赛的同步,一般这个比赛的题目都比较水,就像这次一样,拿下4,5题不是问题!然而普通的div2,就没有这么好的条件了,真是冲分的好机会!这次做了4题,都是读完题,就有思路,稍微思考一下边界条件,然后码代码就可以了!然后,d题怎么也过不去,后来分析是没有仔细思考,一是枚举的方式不太好,二是这种的边界不好处理!然后就去码e题,居然一次就过了,但是后怕system test会挂,后来听说这题的checker有问题,算是水过了!然后再看了看d题,就没时间了!f题和g题,都没有看!

后来看了下f和g题,g题跟以前的一道题目很相似,然后画了画简单例子,码完就过了。f题实在没什么思路!

这里写一下看完f题的想法,或者是为什么无从下手的原因,或者是什么困惑:

1. 数据范围很大,n=2e5,k=1e9,如果考虑用dp的话,这个数据范围不行啊,考虑dp的原因是:因为不知道那些歌曲该取半,哪些不该取半!

2. 看完官方题解和讨论后,感觉上面的考虑就是扯淡,根本一点关联也没有!

原因是:a. 听的歌曲可以从任意位置开始

b. k时间内听得歌曲都必须听,不能跳过(而这点就限制了,解题思路不能往dp方向考虑,而是区间)

c. 最关键的是:这里固定区间,使得收益最大,(每首歌曲的收益都是正数,没有负数和0,而且听的时间减半也不会对收益造成影响),那么收益最大就是听尽可能多的歌曲,那么,很容易得出结论,(这个题目的限制条件,取半的歌曲的数目上限为w),寻找区间,使得区间内听歌时间最大的w个的歌曲取半,这样得到的是这个区间的最大收益值,这样结果很明确,不容考虑各种组合,不需要枚举,不需要dp,(反正这里也不能dp),最优的也就那么一种。

d. 最终的答案就是遍历所有可能这样区间即可,固定左边界,右边界是非递减的,这就可以使用two pointer来做!

3. 接下来就是码代码,知道思想以后,还有一条鸿沟,就是考虑使用什么数据结构,ac了才是王道。

4. 一开始看题,是在想不明白这题的tag是data structure,现在恍然大悟。

5. 思路里面还有一个小细节,删除的时候需要考虑的,这题还是有一定难度的。质量很高!

这里贴一个别人的代码:写的很清晰,简单,漂亮!

 /* Author haleyk10198 */
/* �@��: haleyk10198 */
#include <bits/stdc++.h> #define MOD 1000000007
#define LINF (1LL<<60)
#define INF 2147483647
#define PI 3.1415926535897932384626433
#define ll long long
#define pii pair<int,int>
#define mp(x,y) make_pair((x),(y)) using namespace std; string itos(int x){
stringstream ss;
ss<<x;
return ss.str();
} int n, m, k, a[], b[], tt, res, now; set<pii> h1, h2; int main(){
//freopen("input.txt","r",stdin);
//freopen("output.txt","w",stdout);
ios_base::sync_with_stdio(false);
cin >> n >> m >> k;
for(int i = ; i < n; i++)
cin >> a[i];
for(int i = ; i < n; i++)
cin >> b[i];
for(int l = , r = ; r < n; ){
while(tt <= k && r < n){
if(h1.size() < m){
h1.insert(mp(b[r], r));
tt += (b[r] + ) / ;
}
else if(h1.begin()->first < b[r]){
tt -= (h1.begin()->first + ) / ;
tt += h1.begin()->first;
tt += (b[r] + ) / ;
h2.insert(*h1.begin());
h1.erase(*h1.begin());
h1.insert(mp(b[r], r));
}
else{
h2.insert(mp(b[r], r));
tt += b[r];
}
now += a[r++];
if(tt <= k)
res = max(res, now);
}
while(tt > k){
if(h1.count(mp(b[l], l))){
tt -= (b[l] + ) / ;
h1.erase(mp(b[l], l));
if(!h2.empty()){
auto x = *h2.rbegin();
tt -= x.first;
tt += (x.first + ) / ;
h1.insert(x);
h2.erase(x);
}
}
else{
tt -= b[l];
h2.erase(mp(b[l], l));
}
now -= a[l++];
if(tt <= k)
res = max(res, now);
}
}
cout << res << endl;
return ;
}

F. Music in Car的更多相关文章

  1. Mysql_以案例为基准之查询

    查询数据操作

  2. 在 C# 里使用 F# 的 option 变量

    在使用 C# 与 F# 混合编程的时候(通常是使用 C# 实现 GUI,F#负责数据处理),经常会遇到要判断一个 option 是 None 还是 Some.虽然 Option module 里有 i ...

  3. 如果你也会C#,那不妨了解下F#(7):面向对象编程之继承、接口和泛型

    前言 面向对象三大基本特性:封装.继承.多态.上一篇中介绍了类的定义,下面就了解下F#中继承和多态的使用吧.

  4. 如果你也会C#,那不妨了解下F#(2):数值运算和流程控制语法

    本文链接:http://www.cnblogs.com/hjklin/p/fs-for-cs-dev-2.html 一些废话 一门语言火不火,与语言本身并没太大关系,主要看语言的推广. 推广得好,用的 ...

  5. 使用F#开发ASP.NET Core应用程序

    .NET Core 里的F# 在.NET Core刚发布时,就已经添加了对F#的支持.但因为当时F#组件还不完整,而一些依赖包并没有放在Nuget上,而是社区自己放到MyGet上,所以在使用dotne ...

  6. 如果你也会C#,那不妨了解下F#(6):面向对象编程之“类”

    前言 面向对象的思想已经非常成熟,而使用C#的程序员对面向对象也是非常熟悉,所以我就不对面向对象进行介绍了,在这篇文章中将只会介绍面向对象在F#中的使用. F#是支持面向对象的函数式编程语言,所以你用 ...

  7. 如果你也会C#,那不妨了解下F#(5):模块、与C#互相调用

    F# 项目 在之前的几篇文章介绍的代码都在交互窗口(fsi.exe)里运行,但平常开发的软件程序可能含有大类类型和函数定义,代码不可能都在一个文件里.下面我们来看VS里提供的F#项目模板. F#项目模 ...

  8. 如果你也会C#,那不妨了解下F#(4):了解函数及常用函数

    函数式编程其实就是按照数学上的函数运算思想来实现计算机上的运算.虽然我们不需要深入了解数学函数的知识,但应该清楚函数式编程的基础是来自于数学. 例如数学函数\(f(x) = x^2+x\),并没有指定 ...

  9. 如果你也会C#,那不妨了解下F#(3):F#集合类型和其他核心类型

    本文链接:http://www.cnblogs.com/hjklin/p/fs-for-cs-dev-3.html 在第一篇中,我们介绍了一些基础数据类型,其实那篇标题中不应该含有"F#&q ...

  10. 如果你也会C#,那不妨了解下F#(1):F# 数据类型

    本文链接:http://www.cnblogs.com/hjklin/p/fs-for-cs-dev-1.html 简单介绍 F#(与C#一样,念作"F Sharp")是一种基于. ...

随机推荐

  1. 怎样通过Java程序提交yarn的mapreduce计算任务

    因为项目需求,须要通过Java程序提交Yarn的MapReduce的计算任务.与一般的通过Jar包提交MapReduce任务不同,通过程序提交MapReduce任务须要有点小变动.详见下面代码. 下面 ...

  2. set与hash_set

    原文:http://blog.csdn.net/morewindows/article/details/7029587 STL系列之六 set与hash_set set和hash_set是STL中比较 ...

  3. 40 JavaScript Chart and Graph Libraries for Developers--reference

    reference:http://www.egrappler.com/javascript-chart-and-graph-libraries-for-developers/ BY TEAMEGRAP ...

  4. 关于Google Chorme中字体小于12px的问题

    问题:当字体大小设置成小于12px时,Google chrome中字体的大小始终显示为12px. 而其他浏览器则没有这个问题. 这时只需要在要改变字体大小的元素中添加 -webkit-transfor ...

  5. openlayers加载百度地图

    最近在做openlayers添加百度地图的扩展类,经过轮番的尝试,终于将其接入了,但是发现偏差比较大,有根据百度的坐标进行了比对,将切片原点进行了调整,发现OK了.打开百度地图,可以看出切片的路径如: ...

  6. 【阿里云产品公测】与云引擎ACE第一次亲密接触

    阿里云用户:林哥神话 公测当然是第一次了.这个第一次亲密接触,但话又说回来对ACE我一直都不是那感兴趣的,但是看到阿里介绍还是那般神奇,再加上200无代金券来更加给力.最后就申请了这次公测. 平时一直 ...

  7. python 基础——generate生成器

    通过列表表达式可以直接生成列表,不过列表一旦生成就需要为所有元素分配内存,有时候会很消耗资源. 所以,如果列表元素可以按照某种算法推算出来,这样就不必创建完整的list,从而节省大量的内存空间. 在P ...

  8. codeforces 675E E. Trains and Statistic(线段树+dp)

    题目链接: E. Trains and Statistic time limit per test 2 seconds memory limit per test 256 megabytes inpu ...

  9. Python执行系统命令的方法

    Python中执行系统命令常见方法有两种: 两者均需 import os (1) os.system # 仅仅在一个子终端运行系统命令,而不能获取命令执行后的返回信息 system(command) ...

  10. hdu 4719 动态规划

    思路:dp[i]表示到第i个点为结尾能获得的最大值,那么dp[i]=h[i]*h[i]+dp[i-x]-h[i-x];(i-l<=x<=i);那么我们可以转换下,以dp[i]-h[i]为新 ...