T1

记当前位置 \(i\) 上的颜色,上次出现的位置为 \(last_{1}\) ,上上次出现的位置为 \(last_{2}\) ,则,把当前点的颜色加进来,并且让其产生贡献的话,则会对 \([last_{2}+1,last_{1}]\) ,造成 \(-val_{i}\) 的贡献,对 \([last_{1}+1,i]\) 造成 \(val_{i}\) 的贡献。

发现就是个区间加,用线段树维护,每次加入新颜色后的最大值就是 \(1\) 号节点所存储的信息。

Code
#include<cstdio>
#define MAX 1000010
#define re register
#define int64_t long long
namespace OMA
{
int n,m,c[MAX],d[MAX],last[MAX][2];
template<typename type>inline type max(type a,type b)
{ return a>b?a:b; }
struct Segment_Tree
{
struct TREE
{
//int l,r;
int64_t xam;
int64_t lazy;
}st[MAX<<2];
#define ls(p) p<<1
#define rs(p) p<<1|1
#define mid(p) (lp+rp>>1)
inline void Push_up(int p)
{ st[p].xam = max(st[ls(p)].xam,st[rs(p)].xam); }
inline void Push_down(int p)
{
if(st[p].lazy)
{
st[ls(p)].xam += st[p].lazy;
st[rs(p)].xam += st[p].lazy;
st[ls(p)].lazy += st[p].lazy;
st[rs(p)].lazy += st[p].lazy;
st[p].lazy = 0;
}
}
/*inline void build(int p,int l,int r)
{
st[p].l = l,st[p].r = r;
if(l==r)
{ return ; }
build(ls(p),l,mid(p)),build(rs(p),mid(p)+1,r);
}*/
inline void update(int p,int l,int r,int val,int lp,int rp)
{
if(l<=lp&&rp<=r)
{ st[p].xam += val,st[p].lazy += val; return ; }
Push_down(p);
if(l<=mid(p))
{ update(ls(p),l,r,val,lp,mid(p)); }
if(r>mid(p))
{ update(rs(p),l,r,val,mid(p)+1,rp); }
Push_up(p);
}
}Tree;
struct stream
{
template<typename type>inline stream &operator >>(type &s)
{
int w=1; s=0; char ch=getchar();
while(ch<'0'||ch>'9'){ if(ch=='-')w=-1; ch=getchar(); }
while(ch>='0'&&ch<='9'){ s=s*10+ch-'0'; ch=getchar(); }
return s*=w,*this;
}
}cin;
signed main()
{
cin >> n >> m;
for(re int i=1; i<=n; i++)
{ cin >> c[i]; }
for(re int i=1; i<=m; i++)
{ cin >> d[i]; }
//Tree.build(1,1,n);
int64_t ans = 0;
for(re int i=1; i<=n; i++)
{
if(last[c[i]][0])
{
Tree.update(1,last[c[i]][0]+1,last[c[i]][1],-d[c[i]],1,n);
Tree.update(1,last[c[i]][1]+1,i,d[c[i]],1,n);
}
else if(last[c[i]][1])
{
Tree.update(1,1,last[c[i]][1],-d[c[i]],1,n);
Tree.update(1,last[c[i]][1]+1,i,d[c[i]],1,n);
}
else
{ Tree.update(1,1,i,d[c[i]],1,n); }
last[c[i]][0] = last[c[i]][1];
last[c[i]][1] = i;
//printf("max now := %lld\n",Tree.st[1].xam);
ans = max(ans,Tree.st[1].xam);
}
printf("%lld\n",ans);
return 0;
}
}
signed main()
{ return OMA::main(); }

T2

发现最优的且非0的距离,肯定是一个点经过了一个跟它距离为0的点,到达了另一个点。

考虑将坐标系旋转45度,则原先点的坐标变成了 \((\frac{\sqrt{2}(x-y)}{2},\frac{\sqrt{2}(x+y)}{2})\) ,为了方便,直接在此乘上一个 \(\sqrt{2}\) ,这样算答案时就不用再乘了,坐标转换在读入时就可以完成。

转换完坐标后,此题答案就是 \(\min((x-y),(x+y))\) 。

考虑按 \(x\) 排序,将 \(x\) 相等的放进一个集合中,表示这些点之间的距离为 \(0\) 。

再按 \(y\) 排序,同样将 \(y\) 相等的放进一个集合。

上面两步可以用并查集实现。

找最小值,就再按 \(x\) 排一遍序,找第一个跟它u不在一个集合内的更新答案,并将满足最小答案的都记下来,同样的,按 \(y\) 再做一边。

最后统计对数,就是合法的集合的大小相乘即可,记得去重。

Code
#include<vector>
#include<cstdio>
#include<algorithm>
#define MAX 100010
#define re register
#define INF 2147483647
using std::sort;
using std::unique;
using std::vector;
using std::pair;
using std::make_pair;
namespace OMA
{
int n,cnt,ans=INF;
struct my
{ int x,y,id; }p[MAX];
vector<pair<int,int>>edge;
inline bool cmp1(const my &a,const my &b)
{ return a.x<b.x; }
inline bool cmp2(const my &a,const my &b)
{ return a.y<b.y; }
inline int abs(int a)
{ return a>=0?a:-a; }
inline int min(int a,int b)
{ return a<b?a:b; }
int fa[MAX],size[MAX];
inline int find(int x)
{ return x!=fa[x]?fa[x] = find(fa[x]):x; }
inline void merge(int x,int y)
{
int r1 = find(x),r2 = find(y);
if(r1!=r2)
{
fa[r1] = r2;
size[r2] += size[r1];
}
}
inline void solve()
{
for(re int i=1; i<=n-1; i++)
{
for(re int j=i+1,r1,r2; j<=n; j++)
{
if((r1 = find(fa[p[i].id])) != (r2 = find(fa[p[j].id])))
{
int now = min(abs(p[i].x-p[j].x),abs(p[i].y-p[j].y));
if(now<=ans)
{
if(now<ans)
{ edge.clear(); ans = now; }
edge.push_back(make_pair(r1,r2));
edge.push_back(make_pair(r2,r1));
}
break ;
}
}
}
}
struct stream
{
template<typename type>inline stream &operator >>(type &s)
{
int w=1; s=0; char ch=getchar();
while(ch<'0'||ch>'9'){ if(ch=='-')w=-1; ch=getchar(); }
while(ch>='0'&&ch<='9'){ s=s*10+ch-'0'; ch=getchar(); }
return s*=w,*this;
}
}cin;
signed main()
{
//freopen("node.in","r",stdin);
cin >> n;
for(re int i=1,x,y; i<=n; i++)
{
fa[i] = i,size[i] = 1;
cin >> x >> y; p[i] = (my){x-y,x+y,i};
}
sort(p+1,p+1+n,cmp1);
for(re int i=1; i<=n-1; i++)
{
if(p[i].x==p[i+1].x)
{ merge(p[i].id,p[i+1].id); }
}
sort(p+1,p+1+n,cmp2);
for(re int i=1; i<=n-1; i++)
{
if(p[i].y==p[i+1].y)
{ merge(p[i].id,p[i+1].id); }
}
sort(p+1,p+1+n,cmp1); solve();
sort(p+1,p+1+n,cmp2); solve();
if(ans==INF)
{ printf("-1\n"); }
else
{
sort(edge.begin(),edge.end());
edge.erase(unique(edge.begin(),edge.end()),edge.end());
for(re int i=0; i<edge.size(); i++)
{ cnt += size[edge[i].first]*size[edge[i].second]; }
printf("%d\n%d\n",ans,cnt/2);
}
return 0;
}
}
signed main()
{ return OMA::main(); }

T3

小心CE

int64_t bin[MAX]={1};

noip40的更多相关文章

  1. [XJOI]noip40 T2统计方案

    统计方案 小B写了一个程序,随机生成了n个正整数,分别是a[1]..a[n],他取出了其中一些数,并把它们乘起来之后模p,得到了余数c.但是没过多久,小B就忘记他选了哪些数,他想把所有可能的取数方案都 ...

随机推荐

  1. 2012年第三届蓝桥杯C/C++程序设计本科B组省赛 取球博弈

    2012年第三届蓝桥杯C/C++程序设计本科B组省赛 取球博弈 题目描述 **取球博弈 今盒子里有n个小球,A.B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,也可以看到盒中还剩下多少个,并 ...

  2. DRF之JWT认证

    一.JWT认证 JWT构成 JWT分为三段式:头.体.签名(head.payload.sgin) 头和体是可逆加密的,让服务器可以反解析出user对象,签名是不可逆加密,保证整个token的安全性的. ...

  3. Pytest学习笔记12-配置文件pytest.ini

    前言 pytest配置文件可以改变pytest的运行方式,它是一个固定的文件pytest.ini文件,读取配置信息,按指定的方式去运行. 常用的配置项 marks 作用:测试用例中添加了自定义标记( ...

  4. Vmware 恢复flat.vmdk和delta.vmdk

    背景: 一次客户现场突然掉电,导致虚拟机文件夹里面的文件丢失,只剩余-flat.vmdk和-delta.vmdk文件,其他文件全部丢失,文件格式原本为"文件"格式.新建虚拟机无法直 ...

  5. java二叉树的遍历(1)

    树(tree)是一种抽象数据类型(ADT),用来模拟具有树状结构性质的数据集合.它是由n(n>0)个有限节点通过连接它们的边组成一个具有层次关系的集合 节点:上图的圆圈,比如A,B,C等都是表示 ...

  6. python找出字典中value最大值的几种方法

    假设定义一字典,m = {"a":3,"e":6,"b":2,"g":7,"f":7,"c ...

  7. 让我手把手教你写一个强大、方便使用的 IOC 容器

    一.介绍 1.介绍 最近无聊,也没什么事做,没事做总是要给自己找点事情做吧,毕竟人的生活在与折腾.于是,决定自己手动写一个 IOC 的框架.我们知道在 NetCore 的版本里面已经内置了 IOC 容 ...

  8. Kubernetes 1.13.3 部署 Prometheus+Grafana-7.5.2(最新版本踩坑)

    本教程直接在 Kubernetes 1.13.3 版本上安装 Prometheus 和 Grafana-7.5.2,至于它们的原理和概念就不再赘述,这里就直接开始操作. Git 下载相关 YAML 文 ...

  9. 懂得分享 Linux 配置NFS共享服务

    部署YUM仓库及NFS共享服务一.YUM概述    YUM (Yellow dog Updater Modified)二.准备安装源    ① 软件仓库的提供方式    ② RPM软件包的来源    ...

  10. CTF-safer-than-rot13-writeup

    safer-than-rot13 题目信息 附件: cry100 XMVZGC RGC AMG RVMG HGFGMQYCD VT VWM BYNO, NSVWDS NSGO RAO XG UWFN ...