T1 送花


线段树。枚举右端点,线段树记录左端点对应的值。

每次对当前颜色上上次出现的位置到上次出现的位置区间减,上次出现的位置到当前位置区间加。

$code:$

 1 #include<bits/stdc++.h>
2 #define LL long long
3 using namespace std;
4 const int NN=1e6+5;
5 int n,m,c[NN],d[NN],pre[NN][2];
6 LL ans;
7 inline int read(){
8 int x=0,f=1; char ch=getchar();
9 while(ch<'0'||ch>'9'){ if(ch=='-') f=-1; ch=getchar(); }
10 while(ch>='0'&&ch<='9'){ x=(x<<1)+(x<<3)+(ch^48); ch=getchar(); }
11 return x*f;
12 }
13 inline void write(LL x,char sp){
14 char ch[20]; int len=0;
15 if(x<0){ putchar('-'); x=~x+1; }
16 do{ ch[len++]=x%10+(1<<5)+(1<<4); x/=10; }while(x);
17 for(int i=len-1;~i;i--) putchar(ch[i]); putchar(sp);
18 }
19 struct segment_tree{
20 #define ld rt<<1
21 #define rd (rt<<1)|1
22 LL mx[NN<<2],laz[NN<<2];
23 void pushup(int rt){
24 mx[rt]=max(mx[ld],mx[rd]);
25 }
26 void pushdown(int rt){
27 if(!laz[rt]) return;
28 laz[ld]+=laz[rt]; laz[rd]+=laz[rt];
29 mx[ld]+=laz[rt]; mx[rd]+=laz[rt];
30 laz[rt]=0;
31 }
32 void modify(int rt,int l,int r,int opl,int opr,int val){
33 if(l>=opl&&r<=opr){
34 mx[rt]+=val;
35 laz[rt]+=val;
36 return;
37 }
38 pushdown(rt);
39 int mid=(l+r)>>1;
40 if(opl<=mid) modify(ld,l,mid,opl,opr,val);
41 if(opr>mid) modify(rd,mid+1,r,opl,opr,val);
42 pushup(rt);
43 }
44 LL query(int rt,int l,int r,int opl,int opr){
45 if(l>=opl&&r<=opr) return mx[rt];
46 pushdown(rt);
47 int mid=(l+r)>>1;
48 LL ans=0;
49 if(opl<=mid) ans=max(ans,query(ld,l,mid,opl,opr));
50 if(opr>mid) ans=max(ans,query(rd,mid+1,r,opl,opr));
51 return ans;
52 }
53 }s;
54 signed main(){
55 n=read(); m=read();
56 for(int i=1;i<=n;i++) c[i]=read();
57 for(int i=1;i<=m;i++) d[i]=read();
58 for(int i=1;i<=n;i++){
59 if(pre[c[i]][0]) s.modify(1,1,n,pre[c[i]][1]+1,pre[c[i]][0],-d[c[i]]);
60 s.modify(1,1,n,pre[c[i]][0]+1,i,d[c[i]]);
61 ans=max(ans,s.query(1,1,n,1,n));
62 pre[c[i]][1]=pre[c[i]][0]; pre[c[i]][0]=i;
63 }
64 write(ans,'\n');
65 return 0;
66 }

T1

T2 星空


并查集合并距离为零的点,$O(n^2)$有$70pts$。

考虑优化。发现令$b=x+y$,$B=x-y$,那么两个点的直接距离其实为$min(|b_i-b_j|,|B_i-B_j|)$。

于是可以排序后扫一遍得出答案。点对数只要去重后将两个符合条件的并查集大小相乘后累加。

注意排序后点集的下标改变,所有并查集操作都要通过$id$来实现。

$code:$

 1 #include<bits/stdc++.h>
2 #define mp make_pair
3 using namespace std;
4 const int NN=1e5+5;
5 int n,x[NN],y[NN],fa[NN],siz[NN],ans=INT_MAX,num;
6 map<pair<int,int>,bool>vis;
7 vector<pair<int,int> >vec;
8 struct loc{ int x,y,b1,b2,id; }l[NN];
9 inline bool cmp1(loc a,loc b){ return a.b1<b.b1; }
10 inline bool cmp2(loc a,loc b){ return a.b2<b.b2; }
11 inline int getfa(int x){ return fa[x]==x?x:fa[x]=getfa(fa[x]); }
12 inline int read(){
13 int x=0,f=1; char ch=getchar();
14 while(ch<'0'||ch>'9'){ if(ch=='-') f=-1; ch=getchar(); }
15 while(ch>='0'&&ch<='9'){ x=(x<<1)+(x<<3)+(ch^48); ch=getchar(); }
16 return x*f;
17 }
18 inline void write(int x,char sp){
19 char ch[20]; int len=0;
20 if(x<0){ putchar('-'); x=~x+1; }
21 do{ ch[len++]=x%10+(1<<5)+(1<<4); x/=10; }while(x);
22 for(int i=len-1;~i;i--) putchar(ch[i]); putchar(sp);
23 }
24 void merge(int x,int y){
25 x=getfa(x); y=getfa(y);
26 if(x==y) return;
27 fa[y]=x; siz[x]+=siz[y];
28 }
29 signed main(){
30 n=read();
31 for(int i=1;i<=n;i++){
32 l[i].x=read(); l[i].y=read();
33 fa[i]=i; siz[i]=1; l[i].id=i;
34 l[i].b1=l[i].y-l[i].x;
35 l[i].b2=l[i].y+l[i].x;
36 }
37 sort(l+1,l+n+1,cmp1);
38 for(int i=1;i<n;i++)
39 if(l[i].b1==l[i+1].b1) merge(l[i].id,l[i+1].id);
40 sort(l+1,l+n+1,cmp2);
41 for(int i=1;i<n;i++)
42 if(l[i].b2==l[i+1].b2) merge(l[i].id,l[i+1].id);
43 sort(l+1,l+n+1,cmp1);
44 for(int i=1;i<n;i++){
45 if(getfa(l[i].id)==getfa(l[i+1].id)) continue;
46 if(l[i+1].b1==l[i].b1) continue;
47 if(ans>=l[i+1].b1-l[i].b1){
48 if(ans>l[i+1].b1-l[i].b1) vec.clear();
49 vec.push_back(mp(getfa(l[i].id),getfa(l[i+1].id)));
50 ans=l[i+1].b1-l[i].b1;
51 }
52 }
53 sort(l+1,l+n+1,cmp2);
54 for(int i=1;i<n;i++){
55 if(getfa(l[i].id)==getfa(l[i+1].id)) continue;
56 if(l[i+1].b2==l[i].b2) continue;
57 if(ans>=l[i+1].b2-l[i].b2){
58 if(ans>l[i+1].b2-l[i].b2) vec.clear();
59 vec.push_back(mp(getfa(l[i].id),getfa(l[i+1].id)));
60 ans=l[i+1].b2-l[i].b2;
61 }
62 }
63 if(vec.empty()){ puts("0"); return 0;}
64 for(int i=0;i<vec.size();i++){
65 if(vis[vec[i]]) continue;
66 vis[vec[i]]=1;
67 vis[mp(vec[i].second,vec[i].first)]=1;
68 num+=siz[vec[i].first]*siz[vec[i].second];
69 }
70 write(ans,'\n'); write(num,'\n');
71 return 0;
72 }

T2

T3 零一串


因为不可抗力詁了(连咕两场的怠惰罪该万死

2021.8.15考试总结[NOIP模拟40]的更多相关文章

  1. 2021.7.15考试总结[NOIP模拟16]

    ZJ模拟D2就是NB.. T1 Star Way To Heaven 谁能想到这竟是个最小生成树呢?(T1挂分100的高人JYF就在我身边 把上边界和下边界看成一个点和星星跑最小生成树,从上边界开始跑 ...

  2. 2021.10.15考试总结[NOIP模拟77]

    \(n=40\)考虑\(meet \;in \;the \;middle\) 某个元素有关的量只有一个时考虑转化为树上问题 对暴力有自信,相信数据有梯度 没了 UPD:写了个略说人话的. T1 最大或 ...

  3. 2021.9.17考试总结[NOIP模拟55]

    有的考试表面上自称NOIP模拟,背地里却是绍兴一中NOI模拟 吓得我直接文件打错 T1 Skip 设状态$f_i$为最后一次选$i$在$i$时的最优解.有$f_i=max_{j<i}[f_j+a ...

  4. 2021.9.13考试总结[NOIP模拟52]

    T1 路径 考虑每一位的贡献,第$i$位每$2^i$个数会变一次,那么答案为$\sum_{i=1}^{log_2n} \frac{n}{2^i}$. $code:$ 1 #include<bit ...

  5. 2021.8.11考试总结[NOIP模拟36]

    T1 Dove玩扑克 考场并查集加树状数组加桶期望$65pts$实际$80pts$,考后多开个数组记哪些数出现过,只扫出现过的数就切了.用$set$维护可以把被删没的数去掉,更快. $code:$ 1 ...

  6. 2021.7.29考试总结[NOIP模拟27]

    T1 牛半仙的妹子图 做法挺多的,可以最小生成树或者最短路,复杂度O(cq),c是颜色数. 我考场上想到了原来做过的一道题影子,就用了并查集,把边权排序后一个个插入,记录权值的前缀和,复杂度mlogm ...

  7. 2021.9.14考试总结[NOIP模拟53]

    T1 ZYB和售货机 容易发现把每个物品都买成$1$是没有影响的. 然后考虑最后一个物品的方案,如果从$f_i$向$i$连边,发现每个点有一个出度多个入度,可以先默认每个物品都能买且最大获利,这样可以 ...

  8. 2021.9.12考试总结[NOIP模拟51]

    T1 茅山道术 仔细观察发现对于每个点只考虑它前面第一个与它颜色相同的点即可. 又仔细观察发现对一段区间染色后以这个区间内点为端点的区间不能染色. 于是对区间右端点而言,区间染色的贡献为遍历到区间左端 ...

  9. 2021.9.9考试总结[NOIP模拟50]

    T1 第零题 神秘结论:从一个点满体力到另一个点的复活次数与倒过来相同. 于是预处理出每个点向上走第$2^i$个死亡点的位置,具体实现可以倍增或二分. 每次询问先从两个点同时向上倍增,都转到离$LCA ...

随机推荐

  1. Stream流思想和常用方法

    一.IO流用于读写:Stream流用于处理数组和集合数据: 1.传统集合遍历: 2.使用Stream流的方式过滤: 其中,链式编程(返回值就是对象自己)中,filter使用的是Predicate函数式 ...

  2. 【第十七篇】- Maven Web 应用之Spring Cloud直播商城 b2b2c电子商务技术总结

    Maven Web 应用 本章节我们将学习如何使用版本控制系统 Maven 来管理一个基于 web 的项目,如何创建.构建.部署已经运行一个 web 应用. 创建 Web 应用 我们可以使用 mave ...

  3. Mongodb的基本使用及对接多数据源

    mongodb介绍 MongoDB(来自于英文单词"Humongous",中文含义为"庞大")是可以应用于各种规模的企业.各个行业以及各类应用程序的开源数据库. ...

  4. Java面向对象系列(3)- 回顾方法的调用

    方法的调用 静态方法 非静态方法 形参和实参 值传递和引用传递 this关键字(继承篇讲解) 静态方法 非静态方法 形参和实参 package oop.demo01; public class Dem ...

  5. Shell系列(36)- for循环语法二简介及批量添加删除用户

    for循环语法二 for ((初始值;循环控制条件;变量变化)) do 程序 done 例子 例子-1 求和工具 需求:根据用户输入的数字,求1~输入所有数字的和 脚本: #!/bin/bash re ...

  6. Modern PHP 使用生成器yield 处理csv文件 Generator

    * 使用生成器处理csv文件 <?php function getRows($file) { $handle = fopen($file, 'rb'); if ($handle === fals ...

  7. webpack工具学习 构建简单vue项目(不依赖vue-cli) webpack4.0

    目的用webpack构建简单前端项目 1.npm init   (npm init -y)  形成package.json 2.npm install --save-dev webpack  形成 n ...

  8. LR11自带网站

    LR自带的飞机订票系统 启动服务:安装路径\HP\LoadRunner\WebTours下的StartServer.bat 打开网页:地址  http://127.0.0.1:1080/WebTour ...

  9. VMware虚拟机常见问题(针对目前我所学的而言,还会不断更新)

    VMware虚拟机常见问题(针对目前我所学的而言,还会不断更新) 自己电脑的telnet Client是否打开 在控制面板->程序->打开或关闭Windows功能 虚拟机的telnet是否 ...

  10. 【大咖直播】Elastic 企业搜索实战工作坊(第一期)

    借助 App Search 提供的内置功能,您可轻松打造卓越的搜索体验.直观的相关度调整以及开箱即用的搜索分析,不仅可以优化所提供的内容,其提供的 API 还可帮助您将位于各处的所有内容源关联在一起. ...