繁华模拟赛day8 牛栏
/*
标称并没有用到题解中提到的那种奇妙的性质,我们可以证明,正常从1开始走的话,需要T次,如何使这个次数减小?题解中提到一个办法,有一步小于n/t,我们考虑这一步,如果把它匀到左右两步中,则可以减小,就根据这个性质来优化
next函数的部分,我当时用了一个倍增法,题解用了一个并查集,倍增比较直观,然而并查集更为巧妙
*/
//my code
#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<algorithm>
#include<vector>
#include<queue>
#define ll long long
using namespace std;
const int maxn = ;
int n,q,cnt,ct[maxn];
ll a[maxn],sum[maxn],ans;
ll read(){
char ch=getchar();
ll x=,f=;
while(!(ch>=''&&ch<='')){if(ch=='-')f=-;ch=getchar();};
while(ch>=''&&ch<=''){x=x*+(ch-'');ch=getchar();};
return x*f;
}
ll greedy(int u,ll t){
ll tot = ,tmp = ;
ll j,lg,tst,nt;
for(int i = ;i <= n;i++){
tmp++;
if(a[u] + a[u+] > t || i == n){ }else{
lg = ;
j = ;
tot = ;
while(lg>=){
if(u+j<=n){
tst = sum[u+j]-sum[u-];
nt = u + j;
}
else{
tst = sum[n] - sum[u-] + sum[u+j-n];
nt = u + j - n;
}
if(tot + tst <= t){
i += j;
tot += tst - a[nt];
u = nt;
lg++;
j <<= ;
}else{
lg--;
j >>= ;
}
}
}
u++;
if(u > n) u = ;
if(tmp >= ans) break;
}
return tmp;
}
void work(ll t){
cnt = ;
ans = maxn;
ct[++cnt] = ;
ll sum = a[];
for(int i = n;i > ;i--){
sum += a[i];
if(sum > t) break;
ct[++cnt] = i;
}
for(int i = ;i <= cnt;i++){
ans = min(ans,greedy(ct[i],t));
}
cout<<ans<<endl;
}
int main(){
freopen("stall.in","r",stdin);
freopen("stall.out","w",stdout);
n = read();
q = read();
for(int i = ;i <= n;i++){
a[i] = read();
sum[i] = sum[i-] + a[i];
}
ll b;
for(int i = ;i <= q;i++){
b = read();
work(b);
}
return ;
}
//std
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<vector>
#include<queue>
#include<map>
#include<set>
#include<stack>
#include<cstdlib>
#include<string>
#include<bitset>
#define INF 1000000000
#define N 2000005
#define fi first
#define se second
#define debug(x) cout<<#x<<"="<<x<<endl
#define MP(x,y) make_pair(x,y)
using namespace std;
typedef long long LL;
typedef pair<int,int> pii;
LL a[N],s[N];
int to[N],fa[N],d[N];
int findr(int x)
{
if(fa[x]==x)
return x;
else
{
int t=fa[x];
fa[x]=findr(fa[x]);
d[x]=d[x]+d[t];
return fa[x];
}
} void Union(int x,int y)
{
fa[x]=y;
d[x]=;
} int main()
{
int size = << ; // 256MB
char *p = (char*)malloc(size) + size;
__asm__("movl %0, %%esp\n" :: "r"(p));
freopen("stall.in","r",stdin);
freopen("stall.out","w",stdout);
cin>>n>>q;
for(i=;i<=n;i++)
scanf("%I64d",&a[i]),a[i+n]=a[i];
for(i=n*;i;i--)
s[i]=s[i+]+a[i];
while(q--)
{
ans=INF;
cin>>m;
memset(d,,sizeof(d));
for(i=;i<=n;i++)
fa[i]=i,fa[i+n]=i+n;
for(j=n*,i=n*;i;i--)
{
while(s[i]-s[j+]>m) j--;
to[i]=j+;
//debug(to[i]);
}
//if(q==1) return 0;
for(i=;i<=n;i++)
{
j=findr(i);
while(to[j]<i+n)
{
k=to[j];
Union(j,k);
j=findr(k);
}
findr(i);
ans=min(ans,d[i]);
}
cout<<ans+<<endl;
}
return ;
}
// davidlee1999WTK 2015/
// srO myk Orz
//ios::sync_with_stdio(false);
繁华模拟赛day8 牛栏的更多相关文章
- 繁华模拟赛day8 字典序
/* 这个题要我们求一个字典序,字符串给出的顺序,会对字母的字典序前后相对顺序进行限定,如何用来表示这种限定,我们注意到这种一个之后接着一个,只有先输出他前面的才能输出他,很明显就是拓扑排序,最小方案 ...
- 繁华模拟赛day8 科技树
/* 贪心,很明显是越容易升级的越先升级 */ #include<iostream> #include<cstdio> #include<string> #incl ...
- [繁华模拟赛]Evensgn 剪树枝
Evensgn 剪树枝 题目 繁华中学有一棵苹果树.苹果树有 n 个节点(也就是苹果),n − 1 条边(也就 是树枝).调皮的 Evensgn 爬到苹果树上.他发现这棵苹果树上的苹果有两种:一 种是 ...
- 繁华模拟赛 Vicent坐电梯
/*n<=5000这样就不能用O(n)的转移了,而是要用O(1)的转移.注意我们每次的转移都来自一个连续的区间,而且我们是求和区间求和?前缀和!令sum[step][i]表示f[ste ...
- 繁华模拟赛 Vincent的城堡
#include<iostream> #include<cstdio> #include<string> #include<cstring> #incl ...
- 繁华模拟赛 vicent的字符串
#include<iostream> #include<cstdio> #include<string> #include<cstring> #incl ...
- 繁华模拟赛 Evensgn剪树枝
#include<iostream> #include<cstdio> #include<string> #include<cstring> #incl ...
- 繁华模拟赛 Evensgn玩序列
#include<iostream> #include<cstdio> #include<string> #include<cstring> #incl ...
- 繁华模拟赛 Evensgn的债务
#include<iostream> #include<cstdio> #include<string> #include<cstring> #incl ...
随机推荐
- MyBB \inc\class_core.php <= 1.8.2 unset_globals() Function Bypass and Remote Code Execution(Reverse Shell Exploit) Vulnerability
catalogue . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述 MyBB's unset_globals() function ca ...
- Linux下动态库查找路径的问题
说到和动态库查找路径相关的问题,总体上可以分为两类: 第一类: 通过源代码编译程序时出现的找不到某个依赖包的问题,而如果此时你恰好已经按照它的要求确确实实.千真万确.天地良心地把依赖库给装好了, ...
- AngularJs angular.equals
angular.equals 对比两个对象/值是否相等.支持值类型.正则表达式.数组和对象. 如果下列至少有一个是正确的,则将两个对象/值视为相等. 两个对象/值能通过===比较. 两个对象/值是同一 ...
- 数据结构作业——N!的位数(斯特灵公式)
Description 求N!的位数 Input 输入第一行为一个正整数 n(1<=n<=25000). Output 输出 n!的位数. Sample Input 1020 Sample ...
- 常见Android Native崩溃及错误原因
http://www.droidsec.cn/%E5%B8%B8%E8%A7%81android-native%E5%B4%A9%E6%BA%83%E5%8F%8A%E9%94%99%E8%AF%AF ...
- linux(centos) 项目部署阶段相关命令汇总
1.ssh免密码登陆主要命令cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys-->添加公钥service sshd restart -- ...
- python字符编码(二)
一.什么是字符编码 计算机要想工作必须通电,也就是说‘电’驱使计算机干活,而‘电’的特性,就是高低电压(高低压即二进制数1,低电压即二进制数0),也就是说计算机只认识数字 编程的目的是让计算机干活,而 ...
- VS快捷键大全(总结了一些记忆的口诀)
相信.Net开发人员都想能够熟记各种VS快捷键以提高平时开发的效率,但苦于记忆能力太差而快捷键又特别多,特别烦,所以作罢! 下面我将简单介绍一下我记忆VS快捷键的一些方法,希望对大家有所帮助. 1.窗 ...
- JavaWeb---总结(十二)Session
一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ...
- Objective -C学习笔记 之copy(复制)
//自定义类对象实现copy需要遵守copy协议(否则程序崩溃),实现必须实现的协议方法,里面的代码就决定了你的copy是深是浅 #import <Foundation/Foundation.h ...