Link:

传送门

可能要补一补之前的题了

题目名字天(Sky)的(De)炭(C)好评啊……

A:

从买/卖物品的配对来考虑:

可以发现如果当前物品为卖,肯定从之前选最小的(无论其为买/卖),因为贡献都是差值!

如果要买的物品当前状态为卖,那么相当于将那条匹配链的卖的那一端转换

用优先队列维护$pair(w[i],0/1)$,0/1分别表示当前为卖/买的状态即可

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
const int MAXN=1e5+;
int T,n,cnt,dat[MAXN];ll res=;
priority_queue<P,vector<P>,greater<P> > q; int main()
{
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=;i<=n;i++) scanf("%d",&dat[i]);
res=;cnt=;
while(!q.empty()) q.pop(); q.push(P(dat[],));
for(int i=;i<=n;i++)
{
P t=q.top();
if(dat[i]>t.X)
{
res+=dat[i]-t.X;
cnt+=t.Y;q.pop();
if(!t.Y) q.push(P(t.X,));
q.push(P(dat[i],));
}
else q.push(P(dat[i],));
}
printf("%lld %d\n",res,cnt*);
}
return ;
}

Problem A

考场上写的$O(n^2)$ $dp$发现并不能优化……

其实已经想到用匹配来做,但没发现那条可反悔贪心的性质

一般需要优化的匹配问题除了网络流,都是顺序考虑每一个数而非整体考虑

这里还要注意必须将卖设为0,因为在$w[i]$相同时要先将卖转移

(如果优先队列中放的是结构体,注意每个维度的顺序!)

B:

关键要将上下边界也看成大的障碍点

考虑长度$d$不能通过的条件:

将所有长度小于$d$的连边后上下边界连通,这样一定无法通过这道屏障

用类似$Kruskal$的方法将所有边排序后用并查集维护连通性即可

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
#define pb push_back
typedef double db;
typedef long long ll;
typedef pair<int,int> P;
const int MAXN=2e5+;
P dat[MAXN];
int n,l,f[MAXN],tot;
struct edge{int x,y;double w;}e[MAXN]; double sqr(double a){return a*a;}
bool cmp(edge a,edge b){return a.w<b.w;}
void add_edge(int x,int y,double w)
{e[++tot]=(edge){x,y,w};}
int find(int x)
{return f[x]==x?x:f[x]=find(f[x]);}
double dist(int x,int y)
{return sqrt(sqr(dat[x].X-dat[y].X)+sqr(dat[x].Y-dat[y].Y));} int main()
{
scanf("%d%d",&n,&l);
for(int i=;i<=n;i++)
scanf("%d%d",&dat[i].X,&dat[i].Y);
for(int i=;i<=n+;i++) f[i]=i; for(int i=;i<=n;i++)
add_edge(,i,dat[i].Y),add_edge(i,n+,l-dat[i].Y);
for(int i=;i<=n;i++)
for(int j=i+;j<=n;j++)
add_edge(i,j,dist(i,j)); sort(e+,e+tot+,cmp);
for(int i=;i<=tot;i++)
{
int px=find(e[i].x),py=find(e[i].y);
if(px==py) continue;f[px]=py;
if(find()==find(n+)) return printf("%.3lf",e[i].w),;
}
return ;
}

Problem B

C:

将0/1分别看作-1/1的贡献

发现一个区间需要的最小修改次数为最大的不相交前/后缀和的和

感性证明:

最值:只要某位的前/后缀和大于零该位就一定要删除,因此该值为下界

可行性:如果后面还有大于零的点则一定会向后拓展

两种实现方式:

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
#define mid ((l+r)>>1)
#define lc k<<1,l,mid
#define rc k<<1|1,mid+1,r
typedef double db;
typedef long long ll;
typedef pair<int,int> P;
const int MAXN=2e5+;
int n,m,l,r;char s[MAXN];
struct node{int sum,lmx,rmx,mx;}seg[MAXN<<];
node operator + (node a,node b)
{
node ret;
ret.sum=a.sum+b.sum;
ret.lmx=max(a.lmx,a.sum+b.lmx);
ret.rmx=max(b.rmx,b.sum+a.rmx);
ret.mx=max(a.lmx+b.rmx,max(a.sum+b.mx,b.sum+a.mx));
return ret;
} void build(int k,int l,int r)
{
if(l==r)
{
if(s[l]=='') seg[k]=(node){-,,,};
else seg[k]=(node){,,,};
return;
}
build(lc);build(rc);
seg[k]=seg[k<<]+seg[k<<|];
}
node Query(int a,int b,int k,int l,int r)
{
if(a<=l&&r<=b) return seg[k];
node ret=(node){,,,};
if(a<=mid) ret=Query(a,b,lc);
if(b>mid) ret=ret+Query(a,b,rc);
return ret;
} int main()
{
scanf("%d%d%s",&n,&m,s+);
build(,,n);
for(int i=;i<=m;i++)
scanf("%d%d",&l,&r),printf("%d\n",Query(l,r,,,n).mx);
return ;
}

Solution A

如果求$pre+suf$的最值要注意将区间向外拓展1

(可能取$pre[l-1]$,也就是前缀不选)

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
#define mid ((l+r)>>1)
#define lc k<<1,l,mid
#define rc k<<1|1,mid+1,r
typedef double db;
typedef long long ll;
typedef pair<int,int> P;
const int MAXN=8e5+,INF=<<;
char s[MAXN];
int res,lft;
int n,q,l,r,pre[MAXN],suf[MAXN];
int mx[MAXN],lmx[MAXN],rmx[MAXN]; void pushup(int k)
{
lmx[k]=max(lmx[k<<],lmx[k<<|]);
rmx[k]=max(rmx[k<<],rmx[k<<|]);
mx[k]=max(mx[k<<],max(mx[k<<|],lmx[k<<]+rmx[k<<|]));
} void build(int k,int l,int r)
{
if(l==r)
{
lmx[k]=pre[l],rmx[k]=suf[l];
mx[k]=-INF;return;
}
build(lc);build(rc);
pushup(k);
} void Query(int a,int b,int k,int l,int r)
{
if(a<=l&&r<=b)
{
if(lft==-INF)
res=max(res,mx[k]),lft=lmx[k];
else
res=max(res,max(mx[k],lft+rmx[k])),
lft=max(lft,lmx[k]);
return;
}
if(a<=mid) Query(a,b,lc);
if(b>mid) Query(a,b,rc);
} int main()
{
scanf("%d%d%s",&n,&q,s+);
for(int i=;i<=n;i++)
pre[i]=pre[i-]+(s[i]==''?-:);
for(int i=n;i>=;i--)
suf[i]=suf[i+]+(s[i]==''?-:);
build(,,n+); while(q--)
{
scanf("%d%d",&l,&r);
res=lft=-INF;l--;r++;
Query(l,r,,,n+);
printf("%d\n",res-pre[l]-suf[r]);
}
return ;
}

Solution B

针老师题解里的树上倍增可能不太懂啊……

[ZROI 9.15模拟赛] Tutorial的更多相关文章

  1. [ZROI 9.16模拟赛] Tutorial

    Link: 传送门 A: 套路题结果想了好久…… 排序二叉树的性质就是中序遍历单调递增 于是只考虑当前树的中序遍历的序列即可,与树的形态无关 将序列改成严格单调增想到最大化不变的数,但直接LIS求的是 ...

  2. ZROI提高组模拟赛05总结

    ZROI提高组模拟赛05总结 感觉是目前为止最简单的模拟赛了吧 但是依旧不尽人意... T1 有一半的人在30min前就A掉了 而我花了1h11min 就是一个简单的背包,我硬是转化了模型想了好久,生 ...

  3. ZROI 普及组模拟赛02总结

    ZROI 普及组模拟赛02总结 先放[网址][http://zhengruioi.com/contest/96] 可能是有一段时间没有打这种正式的比赛了,今天打的很奇怪... T1 模拟水题 既然是普 ...

  4. 2014.8.15模拟赛【公主的工作】&&bzoj1046[HAOI2007]上升序列

    bzoj题目是这样的 Description 对于一个给定的S={a1,a2,a3,…,an},若有P={ax1,ax2,ax3,…,axm},满足(x1 < x2 < … < xm ...

  5. NOIP2017提高组 模拟赛15(总结)

    NOIP2017提高组 模拟赛15(总结) 第一题 讨厌整除的小明 [题目描述] 小明作为一个数学迷,总会出于数字的一些性质喜欢上某个数字,然而当他喜欢数字k的时候,却十分讨厌那些能够整除k而比k小的 ...

  6. ZROI 19.08.07模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "正睿从来没有保证,模拟赛的题目必须原创." "文案不是我写的,有问题找喵老师去."--蔡老师 ...

  7. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  8. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  9. 小奇模拟赛9.13 by hzwer

    2015年9月13日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...

随机推荐

  1. 【BZOJ】2134: 单选错位 期望DP

    [题意]有n道题,第i道题有ai个选项.把第i道题的正确答案填到第i+1道题上(n填到1),问期望做对几道题.n<=10^7. [算法]期望DP [题解]正确答案的随机分布不受某道题填到后面是否 ...

  2. 【leetcode 简单】第三十一题 买卖股票的最佳时机

    给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你所能获取的最大利润. 注意你不能在买入股票前卖出股票. 示例 ...

  3. python3爬虫.2.伪装浏览器

    有的网页在爬取时候会报错返回 urllib.error.HTTPError: HTTP Error 403: Forbidden 这是网址在检测连接对象,所以需要伪装浏览器,设置User Agent ...

  4. flask基础之jijia2模板使用基础(二)

    前言 在以前前后端不分离的时代,后台程序员往往又当爹又当妈,需要将前端程序员写的h5页面填充模板语言.而jijia2是一门十分强大的python的模板语言,是flask框架的核心模块之一.先简单介绍一 ...

  5. svn add --no-ignore

    提交新代码时:svn add --no-ignore  /dir   不加的话可能会漏提交某些依赖或文件. Svn st -q --no-ignore. 提交时不需要加

  6. PowerPC简单了解

    PowerPC相对于ARM优势: Powerpc芯片凭借其出色的性能和高度整合和技术先进特性在网络通信应用,工业控制应用,家用数字化,网络存储领域,军工领域,电力系统控制等都具有非常广泛的应用.由于P ...

  7. discuz伪静态设置

        Discuz! 通用伪静态 -包含所有类型主机本人找了一下午才找到的,谢谢这位原创者,发出来让大家用. 第一步:打开后台  全局 SEO设置 全部打勾<ignore_js_op>  ...

  8. centos7安装ssh服务

    1.查看是否安装了相关软件: rpm -qa|grep -E "openssh" 显示结果含有以下三个软件,则表示已经安装,否则需要安装缺失的软件 openssh-ldap-6.6 ...

  9. linux命令:crontab命令(转)

    一.crond简介 crond是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,并且会自动启动cro ...

  10. ioctl socket getsockopt

    一 ioctl 函数产生原因: 虽然在文件操作结构体"struct file_operations"中有很多对应的设备操作函数,但是有些命令是实在找不到对应的操作函数.如CD-RO ...