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. 【CodeForces】913 E. Logical Expression

    [题目]E. Logical Expression [题意]令x=11110000(2),y=11001100(2),z=10101010(2),n次询问,每次要求用[与][或][非][括号]构成含至 ...

  2. 使sqoop能够启用压缩的一些配置

    在使用sqoop 将数据库表中数据导入至hdfs时 配置启用压缩 hadoop 的命令    检查本地库支持哪些  bin/hadoop checknative 需要配置native    要编译版本 ...

  3. sublime格式化css代码插件:css format

    有时会从网上下载一些css压缩文件,打开后所有代码都在一行,不利于阅读,通过css format插件,能快速展开代码,方便阅读. 参考:Sublime Text 上最好用的 CSS 格式化插件 —— ...

  4. java在CMD窗口执行程序的时候输入密码(隐藏一些敏感信息)

    有时候我们需要从CMD窗口执行一些命令,有时候会输入一些敏感的信息,比如密码之类的东西,所以我们可以从控制台读取但是不希望别人看见我们的密码: import java.io.Console; /** ...

  5. 如何通过掩码计算可用的IP数量

    假设掩码是28,28也就是28个1.本身掩码是255.255.255.255那么转换成二进制也就是 11111111,11111111,11111111,11111111 那么28个1也就是: 111 ...

  6. device tree --- #address-cells and #size-cells property

    device tree source Example1 / { #address-cells = <0x1>; // 在 root node 下使用 1 個 u32 來代表 address ...

  7. html---规范、细节积累-01

    语义错误 块级元素可以包含内联元素和某些块级元素,内联元素不能包含块级元素,只能包含内联元素 页面可能正常解析,但不符合语义.浏览器自带容错机制,对于不规范的写法也能够正确解析,各浏览器的容错机制不同 ...

  8. Nginx服务安全设置和参数调优

    1.添加参数隐藏Nginx版本号 vim /application/nginx/conf/nginx.conf #http标签下添加 server_tokens off; #测试 [root@cobb ...

  9. [ python ] 全局和局部作用域变量的引用

    全局与局部变量的引用 (a)locals(b)globals 这里还需要在补充2个关键字一起比较学习,关键字:(c)nonlocal(d)global locals 和 globals locals: ...

  10. RF和adaboost

    通过对所有的决策树进行加总来预测新的数据(在分类时采用多数投票,在回归时采用平均).