临近$CSP$......

下午打了一发月赛,感觉很爽。

非常菜的我只做了前两题......然而听说前两题人均过......

写法不优秀被卡到$#1067$......

T1:基础字符串练习题:

前缀和水题,只需要维护前缀最小值即可

很菜的我选择了用堆维护,凭空多了个$log$。

于是就慢成**了。

注意特判$0$、$1$的情况。

参考代码:

 #include<iostream>
#include<queue>
#include<cstring>
#define N 100005
using namespace std;
char ch[N];
int a[N],ans,n,kkk;
priority_queue<int,vector<int>,greater<int> >q;
int main()
{
cin>>(ch+);
n=strlen(ch+);
for(int i=;i<=n;i++)a[i]=a[i-]+(ch[i]==''?-:);
for(int i=;i<=n;i++)
{
//cout<<a[i]<<" ";
q.push(a[i]);
ans=max(a[i]-q.top(),ans);
}
if(a[n]==-n)cout<<-<<endl;
else if(a[n]==n)cout<<n<<endl;
else cout<<ans<<endl;
return ;
}

T1

T2:基础最短路练习题

讲评人讲了个奇奇怪怪的线性做法,但由于我太菜所以没想出来。

于是我又多了个$log$。

首先考虑树的做法,由于路径唯一,因此可以直接树上倍增找到答案

由于没有任何一个环的$xor$和不为0,所以如何走这些环对我们来说其实不重要,因此我们可以任意找一颗生成树,然后用树的做法得到答案。

 #include<iostream>
#include<cstdio>
#include<cstring>
#define N 300005
using namespace std;
int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=(x<<)+(x<<)+(ch^);ch=getchar();}
return x*f;
}
struct node
{
int a,b,c;
}s[N];
int n,m,q,f[N],fa[N][],dist[N][],v[N],w[N],head[N],nxt[N],cnt,num,dep[N];
int find(int x){return f[x]==x?x:f[x]=find(f[x]);}
void add(int a,int b,int c)
{
v[++cnt]=b;
w[cnt]=c;
nxt[cnt]=head[a];
head[a]=cnt;
}
void dfs(int x,int ff)
{
dep[x]=dep[ff]+;
for(int i=;i<=;i++)
{
fa[x][i+]=fa[fa[x][i]][i];
dist[x][i+]=(dist[x][i]^dist[fa[x][i]][i]);
}
for(int i=head[x];i;i=nxt[i])
{
if(v[i]==ff)continue;
fa[v[i]][]=x;
dist[v[i]][]=w[i];
dfs(v[i],x);
}
}
int lca(int x,int y)
{
if(dep[x]<dep[y])swap(x,y);
for(int i=;i>=;i--)
{
if(dep[fa[x][i]]>=dep[y])x=fa[x][i];
}
if(x==y)return x;
for(int i=;i>=;i--)
{
if(fa[x][i]!=fa[y][i])x=fa[x][i],y=fa[y][i];
}
return fa[x][];
}
int qmax(int x,int y)
{
int ans=;
for(int i=;i>=;i--)
{
if(dep[fa[x][i]]>=dep[y])
{
ans=(ans^dist[x][i]);
x=fa[x][i];
}
}
return ans;
}
int main()
{
n=read();m=read();q=read();
for(int i=;i<=m;i++)s[i].a=read(),s[i].b=read(),s[i].c=read();
for(int i=;i<=n;i++)f[i]=i;
for(int i=;i<=m;i++)
{
int x=s[i].a,y=s[i].b,xx=find(x),yy=find(y);
if(xx!=yy)
{
f[xx]=yy;
add(x,y,s[i].c);
add(y,x,s[i].c);
num++;
}
if(num==n-)break;
}
dfs(,);
while(q--)
{
int x=read(),y=read(),xx=lca(x,y);
cout<<(qmax(x,xx)^qmax(y,xx))<<endl;
}
return ;
}

T2

T3:咕咕咕

T4:咕咕咕

【LGR-065】洛谷11月月赛 III Div.2的更多相关文章

  1. 【LGR-062】洛谷10月月赛 III div.2 (A-C)

    前言 100+100+46+0=246pts 300多名 以后每次比赛都要有进步哦!qwq 小D与笔试 水题 Code #include<algorithm> #include<io ...

  2. 洛谷 11 月月赛 I Div.2 A [Kubic] Addition 题解

    Content 你有一个长度为 \(n\) 的序列 \(a\).你可以执行 \(n-1\) 次操作,每次操作中你可以选择一个位置 \(i\),并删除 \(a_i\) 和 \(a_{i+1}\),再在原 ...

  3. 「P4996」「洛谷11月月赛」 咕咕咕(数论

    题目描述 小 F 是一个能鸽善鹉的同学,他经常把事情拖到最后一天才去做,导致他的某些日子总是非常匆忙. 比如,时间回溯到了 2018 年 11 月 3 日.小 F 望着自己的任务清单: 看 iG 夺冠 ...

  4. 「P4994」「洛谷11月月赛」 终于结束的起点(枚举

    题目背景 终于结束的起点终于写下句点终于我们告别终于我们又回到原点…… 一个个 OIer 的竞赛生涯总是从一场 NOIp 开始,大多也在一场 NOIp 中结束,好似一次次轮回在不断上演.如果这次 NO ...

  5. 「LuoguP4995」「洛谷11月月赛」 跳跳!(贪心

    题目描述 你是一只小跳蛙,你特别擅长在各种地方跳来跳去. 这一天,你和朋友小 F 一起出去玩耍的时候,遇到了一堆高矮不同的石头,其中第 ii 块的石头高度为 h_ihi​,地面的高度是 h_0 = 0 ...

  6. 洛谷11月月赛(284pts rank85)

    https://www.luogu.org/contestnew/show/12006 我是比赛完后在去写的 这是我第一次打洛谷月赛,之前一次是比赛完才去看而且写了第一题就没写后面的了 284分,太水 ...

  7. 洛谷11月月赛round.1

    太感动了#2 thwfhk 240 (801ms) 100 100 40   又一张明信片,话说10月的怎么还没收到   P2246 SAC#1 - Hello World(升级版) 题目背景 一天, ...

  8. 洛谷11月月赛round.2

    P3414 SAC#1 - 组合数 题目背景 本题由世界上最蒟蒻最辣鸡最撒比的SOL提供. 寂月城网站是完美信息教室的官网.地址:http://191.101.11.174/mgzd . 题目描述 辣 ...

  9. 洛谷11月月赛题解(A-C)

    心路历程 辣鸡T3卡我1.5h题意,要不是最后nlh跟我解释了一下大样例估计这次是真凉透了.. A P4994 终于结束的起点 打出暴力来发现跑的过最大数据?? 保险起见还是去oeis了一波,然后被告 ...

随机推荐

  1. 算法复习_线性时间求解Majority Vote Algorithm问题

    题目来源于Leecode上的Majority Element问题 Majority Element:在一个序列中出现了至少n/2的下界次 使用排序算法取中位数则需要Nlogn http://www.c ...

  2. mybatis config 配置设置说明

    <!– 配置设置 –> 2.           <settings> 3.               <!– 配置全局性 cache 的 ( 开 / 关) defau ...

  3. 在postman中请求的接口有csrf怎么办

    今天在写项目的时候,写了一个post接口,为了防止crsf攻击,config.defalut.js文件中加了如下代码: exports.security = { csrf: { ignoreJSON: ...

  4. layui 源码解读(部分)

    <!DOCTYPE html> <head> </head> <body> <input type="button" id=& ...

  5. PHP基础教程 10款人气暴涨的PHP开源工具

    若想创建动态而又新颖的Web应用程序,PHP便是理想的选择.不用说,在Web开发世界里,PHP是最流行的语言之一.一些非常好用的PHP开源工具着实拯救了不少开发任务繁重的PHP开发 人员,减轻他们的开 ...

  6. 【BZOJ2409】 地下车会

    Description 小Y喜欢速度与激情,于是他参加了地下车会.  地下车会设有N 个分赛区,M种赛事.每个分赛区有C[i]场比赛.由于地下车会经营者想要赚到更多的钱,规定小 Y 必须参加某一些赛区 ...

  7. HDU 2612 Find a way(双向bfs)

    题目代号:HDU 2612 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2612 Find a way Time Limit: 3000/1000 M ...

  8. 为什么JPA@Modifying需要@Transactional注解

    在JPA开发中遇到一个很奇怪的问题,@Modifying需要和@Transactional配合使用才能正常使用.如下面代码所示 @Modifying @Transactional @Query(&qu ...

  9. List of Mozilla-Based Applications

    List of Mozilla-Based Applications The following is a list of all known active applications that are ...

  10. Design a stack that supports getMin() in O(1) time and O(1) extra space

    Question: Design a Data Structure SpecialStack that supports all the stack operations like push(), p ...