CF 949D Curfew——贪心(思路!!!)
题目:http://codeforces.com/contest/949/problem/D
有二分答案的思路。
如果二分了一个答案,首先可知越靠中间的应该大约越容易满足,因为方便把别的房间的人聚集过来;所以如果二分了答案为 f ,可以认为合法的房间是除了前 f 个和后 f 个的剩下的房间。
但边缘房间自己能满足时也不用专门往中间跑,但一旦要跑,方向一定是向中间的;所以可以用指针判断;
可以认为 f 是合法房间的一个界限;指针走的时候累计一下已经有多少人,当又满足一个房间时,如果指针在界限 f 之前,说明指针后面的房间的人都不用动;而指针前面房间的人一定能赶上跑到那个房间(最差就是被挤着一个一个房间地走),所以不会在时间上不合法;如果指针在界限 f 之后,说明界限到指针之间房间的相应人数要跑到界限这个房间(每次合法一对房间(前面和后面一起做),界限向中间移动一格),这时要判断一下时间来得及否;时间就是从开头到查到界限 f 这个房间的总用时(从题解上可以看出题意好像是先跑一个单位时间,然后再查一个单位时间;即查 i 房间之前有 i 个单位时间)。
如果一直没有不合法,因为是按人数调指针的,所以一定恰好弄完所有人,最后就是合法的。
先放一份cf上的有自己注释的题解代码:
#include <iostream>
#include <string>
#include <vector>
#include <set>
#include <map>
#include <queue>
#include <cmath>
#include <algorithm> using namespace std; #define FOR(i,a,b) for (int i = (a); i < (b); i++)
#define SZ(a) a.size()
#define LL long long const LL mod = ; int n,d,b;
int a[];
int A[]; bool ok(int num)
{
FOR (i,,n) A[i] = a[i];
LL f1 = num, f2 = n-num-, s1 = , s2 = n-;
//f1:左边第一个需要合法的(从0标号) f2:右边第一个需要合法的
while (f1 < f2)
{
int val, N;
N = b;
while (N && s1-f1 <= 1LL*d*(f1+)) {val = min(A[s1],N), N-= val, A[s1] -= val; if (A[s1] == ) s1++;}
if (N) return false;//查完一个合法房间
//s1>f1怎么理解?s1与s2的相交呢?
//s1不会与s2相交。因为它是看人数的。做完(n+1)/2个N的消耗后,所有a刚好被用完,s1与s2在同一个点
//s1>f1也不怕,因为f1和f2只是一个计时的东西。最后s1和s2的交点是自己合法房间分布的中心
//上一行不太对。因为只要合法房间分布的中心不在所有房间的中心,即意味着有一个宿管超额了
//应当认为越靠中心越容易被满足(大约),s1>f1意味着从后面找人走过来
//s1是指针,就能前一段给f1,之后一段给f1+1……这样贪心
//其实f1的意义是保证f1和它前面的点中这一回有一个合法房间。s1<=f1时相当于没记时间,就是这个意思,
//为了不浪费边界房间
N = b;
while (N && f2-s2 <= 1LL*d*(f1+)) {val = min(A[s2],N), N-= val, A[s2] -= val; if (A[s2] == ) s2--;}
if (N) return false;
f1++; f2--;//自己剩余的合法限度(一旦某个房间合法的过程中使得后面没有足够房间,就崩)
//没有上述情况地做到最后,因为总人数是符合的,所以可以满足
}
return true;
} int main()
{
scanf("%d%d%d",&n,&d,&b);
//n = 4; d = 3; b = 1; a[0] = n*b;
FOR (i,,n) scanf("%d",a+i);
int l = , r = (n+)/;
while (l != r)
{
int x = (l+r)/;
if (ok(x)) r = x;
else l = x+;
}
cout << l;
}
再放上自己的学习(抄)成果:(注意a数组会改变,要每次赋回原值)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const int N=1e5+;
int n,d,b,lm,a[N],c[N],l,r,ans,p0,p1,s;
ll dis;
int rdn()
{
int ret=;bool fx=;char ch=getchar();
while(ch>''||ch<''){if(ch=='-')fx=;ch=getchar();}
while(ch>=''&&ch<='') ret=(ret<<)+(ret<<)+ch-'',ch=getchar();
return fx?ret:-ret;
}
bool check(int f)
{
dis=(ll)d*f; p0=; p1=n;
for(int i=f+;i<=lm;i++)
{
dis+=d; s=b;
while(a[p0]<s)s-=a[p0++]; a[p0]-=s;
if(p0-i>dis)return ; if(i==lm&&(n&))break;
s=b;
while(a[p1]<s)s-=a[p1--]; a[p1]-=s;
if((n-i+)-p1>dis)return ;
}
return ;
}
int main()
{
n=rdn(); d=rdn(); b=rdn(); lm=(n+)>>;
for(int i=;i<=n;i++) c[i]=a[i]=rdn();
l=; r=n+;
while(l<=r)
{
int mid=l+r>>;
memcpy(a,c,sizeof c);
if(check(mid)) ans=mid,r=mid-;
else l=mid+;
}
printf("%d\n",ans);
return ;
}
CF 949D Curfew——贪心(思路!!!)的更多相关文章
- hrbust-1909理工门外的树,不用线段数,贪心思路~~
理工门外的树 Time Limit: 1000 MS Memory Limit: 32768 K Total Submit: 605(125 users) Total Accepted: 154(11 ...
- CF 463A && 463B 贪心 && 463C 霍夫曼树 && 463D 树形dp && 463E 线段树
http://codeforces.com/contest/462 A:Appleman and Easy Task 要求是否全部的字符都挨着偶数个'o' #include <cstdio> ...
- cf 之lis+贪心+思维+并查集
https://codeforces.com/contest/1257/problem/E 题意:有三个集合集合里面的数字可以随意变换位置,不同集合的数字,如从第一个A集合取一个数字到B集合那操作数+ ...
- CF Covered Path (贪心)
Covered Path time limit per test 1 second memory limit per test 256 megabytes input standard input o ...
- CF 389 E 贪心(第一次遇到这么水的E)
http://codeforces.com/contest/389/problem/E 这道题目刚开始想的特别麻烦...但是没想到竟然是贪心 我们只需要知道偶数的时候可以对称取的,然后奇数的时候没次取 ...
- LeetCode 423. Reconstruct Original Digits from English——学会观察,贪心思路
Given a non-empty string containing an out-of-order English representation of digits 0-9, output the ...
- 【BZOJ1124】[POI2008]枪战Maf 贪心+思路题
[BZOJ1124][POI2008]枪战Maf Description 有n个人,每个人手里有一把手枪.一开始所有人都选定一个人瞄准(有可能瞄准自己).然后他们按某个顺序开枪,且任意时刻只有一个人开 ...
- BZOJ3174 Tjoi2013 拯救小矮人(贪心+DP)
传送门 Description 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀上,知道最顶端的小矮人伸直胳膊可以碰到陷阱口.对于每一个 ...
- uva 11134 fabled rooks (贪心)——yhx
We would like to place n rooks, 1 n 5000, on a n nboard subject to the following restrictions• The i ...
随机推荐
- SkipList跳表(一)基本原理
一直听说跳表这个数据结构,说要学一下的,懒癌犯了,是该治治了 为什么选择跳表 目前经常使用的平衡数据结构有:B树.红黑树,AVL树,Splay Tree(这个树好像还没有听说过),Treep(也没有听 ...
- phpmyadmin内存溢出
phpmyadmin Fatal error: Allowed memory size of 134217728 bytes 解决方法: 在报错的页面里,加上这句: ini_set('memory_l ...
- HDU 2473 Junk-Mail Filter(并查集的删除操作)
题目地址:pid=2473">HDU 2473 这题曾经碰到过,没做出来. .如今又做了做,还是没做出来. ... 这题涉及到并查集的删除操作.想到了设一个虚节点,可是我把虚节点设为了 ...
- java中使用js函数
JDK6已经发布很久了,很早就听过他已经支持脚本语言了,不过一直没有时间尝试,今天偷闲试了一下,感觉不错. javax.script包它是Java新增的操作脚本的工具包, 利用它我们可以对脚本语言进行 ...
- 九度OJ 1064:反序数 (基础题)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3758 解决:2773 题目描述: 设N是一个四位数,它的9倍恰好是其反序数(例如:1234的反序数是4321) 求N的值 输入: 程序无任 ...
- iOS App打包上架超详细流程
https://www.jianshu.com/p/817686897ec1?open_source=weibo_search
- Facebook Gradient boosting 梯度提升 separate the positive and negative labeled points using a single line 梯度提升决策树 Gradient Boosted Decision Trees (GBDT)
https://www.quora.com/Why-do-people-use-gradient-boosted-decision-trees-to-do-feature-transform Why ...
- iOS 流布局 UICollectionView使用(使用FlowLayout进行更灵活布局)
在UICollectionView的布局中,如果每个item的大小都一样那么是十分简单的事情,但是,如果我们想要的每个item大小不一样呢,这个时候,就要对UICollectionViewFlowLa ...
- web项目中从不同的路径读取文件
项目中的配置文件可以放在classpath下,webapp下获取其他任何一个指定的绝对地址,读取这些文件就从这三个地方去找.主要代码如下: private List<String> get ...
- drawable canvas使用
/** * Drawable 就是一个可画的对象, * 其可能是一张位图(BitmapDrawable), * 也可能是一个图形(ShapeDrawable), * 还有可能是一个图层(LayerDr ...