APIO2015
还没有写完APIO2015的题目,打算今天写一写。
T1:
按位DP,DP时要保证已确定的位为0。
前4组设f[n][k]表示把前n个分成k组是否合法。
最后一组设g[n]表示把前n个最少分为多少组才符合题意。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cctype>
#define rep(i,s,t) for(int i=s;i<=t;i++)
#define ren for(int i=first[x];i!=-1;i=next[i])
using namespace std;
inline int read() {
int x=,f=;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-;
for(;isdigit(c);c=getchar()) x=x*+c-'';
return x*f;
}
const int maxn=;
typedef long long ll;
int n,A,B,f[][],g[maxn];
ll t,S[maxn];
int check(int x) {
if(A==) {
g[]=;
rep(i,,n) {
g[i]=<<;
rep(j,,i-) if(!((S[i]-S[j])&t)) g[i]=min(g[i],g[j]+);
}
return g[n]<=B;
}
memset(f,,sizeof(f));
f[][]=;
rep(i,,n) rep(k,,B) rep(j,,i-) if(!((S[i]-S[j])&t)&&f[j][k-]) f[i][k]=;
rep(i,A,B) if(f[n][i]) return ;
return ;
}
int main() {
n=read();A=read();B=read();
rep(i,,n) S[i]=S[i-]+read();
ll ans=;
for(int i=;i>=;i--) {
t^=(1ll<<i);
if(!check(i)) ans^=(1ll<<i),t^=(1ll<<i);
}
printf("%lld\n",ans);
return ;
}
T3:
k=1时排序求中位数。
k=2时设垮桥的所有两点坐标分别为x1i,x2i。设桥修在了p1,p2的位置,对于每对点(x1,x2),当(x1+x2)/2接近p1时肯定走p1,(x1+x2)/2接近p2时肯定走p2。故将所有点对按x1+x2升序排序,这样肯定存在一条分割线,使得分割线左侧的走左边一座桥,分割线右侧的走右边一座桥。这样我们实现一个可以支持插入和查询中位数的数据结构即可。Treap什么的就行了,但我DB地用了动态开节点的线段树。
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cctype>
#define rep(s,t) for(int i=s;i<=t;i++)
#define ren for(int i=first[x];i!=-1;i=next[i])
using namespace std;
inline int read() {
int x=,f=;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-;
for(;isdigit(c);c=getchar()) x=x*+c-'';
return x*f;
}
inline char getc() {
char c=getchar();
while(!isalpha(c)) c=getchar();
return c;
}
const int maxn=;
typedef long long ll;
struct Point {
int x1,x2;
bool operator < (const Point& ths) const {return x1+x2<ths.x1+ths.x2;}
}A[maxn];
int k,n,tmp[maxn];
ll ans,mn=(1ll<<),f[maxn],g[maxn],sumv[];
int ls[],rs[],s[],ToT,root;
void insert(int& o,int l,int r,int pos) {
if(!o) o=++ToT,s[o]=ls[o]=rs[o]=sumv[o]=;
s[o]++;sumv[o]+=pos;if(l==r) return;
int mid=l+r>>;
if(pos<=mid) insert(ls[o],l,mid,pos);
else insert(rs[o],mid+,r,pos);
}
int kth(int o,int l,int r,int k) {
if(l==r) return l;
int k2=s[ls[o]],mid=l+r>>;
if(k2>=k) return kth(ls[o],l,mid,k);
return kth(rs[o],mid+,r,k-k2);
}
ll tot,sum;
void query(int o,int l,int r,int ql,int qr) {
if(!o) return;
if(ql<=l&&r<=qr) {
tot+=s[o];sum+=sumv[o];
return;
}
int mid=l+r>>;
if(ql<=mid) query(ls[o],l,mid,ql,qr);
if(qr>mid) query(rs[o],mid+,r,ql,qr);
}
ll query(int o) {
if(!o) return ;
int v=kth(o,,,s[o]/);
ll ret=;
tot=sum=;query(o,,,,v);ret+=tot*v-sum;
tot=sum=;query(o,,,v,);ret-=tot*v-sum;
return ret;
}
int main() {
k=read();n=read();int t=;
rep(,n) {
char t1,t2;int x1,x2;
t1=getc();x1=read();t2=getc();x2=read();
if(t1==t2) ans+=abs(x1-x2);
else A[++t]=(Point){x1,x2};
}
n=t;sort(A+,A+n+);ans+=n;
if(k==) {
t=;
rep(,n) tmp[t++]=A[i].x1,tmp[t++]=A[i].x2;
sort(tmp,tmp+t);
rep(,t-) ans+=abs(tmp[t/]-tmp[i]);
printf("%lld\n",ans);
return ;
}
ToT=root=;
rep(,n) {
insert(root,,,A[i].x1);insert(root,,,A[i].x2);
f[i]=query(root);
}
ToT=root=;
for(int i=n;i;i--) {
g[i]=query(root);
insert(root,,,A[i].x1);insert(root,,,A[i].x2);
}
rep(,n) mn=min(mn,f[i]+g[i]);if(!n) mn=;
printf("%lld\n",ans+mn);
return ;
}
APIO2015的更多相关文章
- APIO2015题解
分组赛讲课讲了APIO2015的题,于是回去就做完了 稍微写一点题解吧 bzoj4069 逐位处理的简单题,然后就是bool型dp 然后a=1 的时候可以把一位状态干掉 当一维状态单调且是bool型d ...
- bzoj千题计划239:bzoj4069: [Apio2015]巴厘岛的雕塑
http://www.lydsy.com/JudgeOnline/problem.php?id=4069 a!=1: 从高位到低位一位一位的算 记录下哪些位必须为0 dp[i][j] 表示前i个数分为 ...
- [APIO2015]巴厘岛的雕塑 --- 贪心 + 枚举
[APIO2015]巴厘岛的雕塑 题目描述 印尼巴厘岛的公路上有许多的雕塑,我们来关注它的一条主干道. 在这条主干道上一共有\(N\)座雕塑,为方便起见,我们把这些雕塑从 1 到\(N\)连续地进行 ...
- 【BZOJ4071】[Apio2015]巴邻旁之桥 Treap
[BZOJ4071][Apio2015]巴邻旁之桥 Description 一条东西走向的穆西河将巴邻旁市一分为二,分割成了区域 A 和区域 B. 每一块区域沿着河岸都建了恰好 1000000001 ...
- 洛谷 P3644 [APIO2015]八邻旁之桥 解题报告
P3644 [APIO2015]八邻旁之桥 题目描述 一条东西走向的穆西河将巴邻旁市一分为二,分割成了区域\(A\)和区域\(B\). 每一块区域沿着河岸都建了恰好\(1000000001\)栋的建筑 ...
- bzoj 4070 [Apio2015]雅加达的摩天楼 Dijkstra+建图
[Apio2015]雅加达的摩天楼 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 644 Solved: 238[Submit][Status][D ...
- bzoj 4069 [Apio2015]巴厘岛的雕塑 dp
[Apio2015]巴厘岛的雕塑 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 494 Solved: 238[Submit][Status][Dis ...
- uoj #111. 【APIO2015】Jakarta Skyscrapers
#111. [APIO2015]Jakarta Skyscrapers 印尼首都雅加达市有 NN 座摩天楼,它们排列成一条直线,我们从左到右依次将它们编号为 00 到 N−1N−1.除了这 NN 座摩 ...
- bzoj4069【APIO2015】巴厘岛的雕塑
4069: [Apio2015]巴厘岛的雕塑 Time Limit: 10 Sec Memory Limit: 64 MB Submit: 192 Solved: 89 [Submit][Stat ...
随机推荐
- 【Django】Django 文件下载最佳实践
代码: from django.http import StreamingHttpResponse def big_file_download(request): # do something... ...
- 【SpringMVC】SpringMVC系列11之Restful的CRUD
11.Restful的CRUD 11.1.需求 11.2.POST转化为PUT.DELETE的fileter 11.3.查询所有 11.4.添加 11.5.删除 优雅的 REST 风格的资 ...
- spring boot实战(第十三篇)自动配置原理分析
前言 spring Boot中引入了自动配置,让开发者利用起来更加的简便.快捷,本篇讲利用RabbitMQ的自动配置为例讲分析下Spring Boot中的自动配置原理. 在上一篇末尾讲述了Spring ...
- 烦烦烦SharePoint2013 以其他用户登录和修改AD域用户密码
sharepoint默认是没有修改AD密码 和切换 用户的功能,这里我用future的方式来实现. 部署wsp前: 部署后 点击以其他用户身份登录 点击修改用户密码: 这里的扩展才菜单我们用Custo ...
- 【转】Mybatis/Ibatis,数据库操作的返回值
该问题,我百度了下,根本没发现什么有价值的文章:还是看源代码(详见最后附录)中的注释,最有效了!insert,返回值是:新插入行的主键(primary key):需要包含<selectKey&g ...
- shell脚本批量生成配置文件
如果管理的站点和服务器较多的情况下,每次修改配置文件都相当痛苦.因而想到了用shell脚本来批量生成配置文件和配置数据.下面这个脚本是为了批量生成nagios监控配置文件的一个shell脚本程序.其原 ...
- js判空
2014年9月3日 11:36:10 转载的: http://blog.sina.com.cn/s/blog_755168af0100vsik.html typeof用法 typeof的运算数未定义, ...
- dt.jar设计时rt.jar运行时
很多人在初学Java的时候,都要配置环境变量.在配置CLASSPATH的时候,都会加上一个当前目录.,还有两个jar:dt.jar和tools.jar.其实好多人都不了解这两个jar的作用,尤其是dt ...
- Oracle主键操作
http://blog.csdn.net/zhanggnol/article/details/6221895
- 注意padding-top 百分比定义基于父元素宽度的百分比上内边距!!是基于宽度
定义和用法 padding-top 属性设置元素的上内边距(空间). 说明 该属性设置元素上内边距的宽度.行内非替换元素上设置的上内边距不会影响行高计算,因此,如果一个元素既有内边距又有背景,从视觉上 ...