【LGR-065】洛谷11月月赛 III Div.2
临近$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的更多相关文章
- 【LGR-062】洛谷10月月赛 III div.2 (A-C)
前言 100+100+46+0=246pts 300多名 以后每次比赛都要有进步哦!qwq 小D与笔试 水题 Code #include<algorithm> #include<io ...
- 洛谷 11 月月赛 I Div.2 A [Kubic] Addition 题解
Content 你有一个长度为 \(n\) 的序列 \(a\).你可以执行 \(n-1\) 次操作,每次操作中你可以选择一个位置 \(i\),并删除 \(a_i\) 和 \(a_{i+1}\),再在原 ...
- 「P4996」「洛谷11月月赛」 咕咕咕(数论
题目描述 小 F 是一个能鸽善鹉的同学,他经常把事情拖到最后一天才去做,导致他的某些日子总是非常匆忙. 比如,时间回溯到了 2018 年 11 月 3 日.小 F 望着自己的任务清单: 看 iG 夺冠 ...
- 「P4994」「洛谷11月月赛」 终于结束的起点(枚举
题目背景 终于结束的起点终于写下句点终于我们告别终于我们又回到原点…… 一个个 OIer 的竞赛生涯总是从一场 NOIp 开始,大多也在一场 NOIp 中结束,好似一次次轮回在不断上演.如果这次 NO ...
- 「LuoguP4995」「洛谷11月月赛」 跳跳!(贪心
题目描述 你是一只小跳蛙,你特别擅长在各种地方跳来跳去. 这一天,你和朋友小 F 一起出去玩耍的时候,遇到了一堆高矮不同的石头,其中第 ii 块的石头高度为 h_ihi,地面的高度是 h_0 = 0 ...
- 洛谷11月月赛(284pts rank85)
https://www.luogu.org/contestnew/show/12006 我是比赛完后在去写的 这是我第一次打洛谷月赛,之前一次是比赛完才去看而且写了第一题就没写后面的了 284分,太水 ...
- 洛谷11月月赛round.1
太感动了#2 thwfhk 240 (801ms) 100 100 40 又一张明信片,话说10月的怎么还没收到 P2246 SAC#1 - Hello World(升级版) 题目背景 一天, ...
- 洛谷11月月赛round.2
P3414 SAC#1 - 组合数 题目背景 本题由世界上最蒟蒻最辣鸡最撒比的SOL提供. 寂月城网站是完美信息教室的官网.地址:http://191.101.11.174/mgzd . 题目描述 辣 ...
- 洛谷11月月赛题解(A-C)
心路历程 辣鸡T3卡我1.5h题意,要不是最后nlh跟我解释了一下大样例估计这次是真凉透了.. A P4994 终于结束的起点 打出暴力来发现跑的过最大数据?? 保险起见还是去oeis了一波,然后被告 ...
随机推荐
- Chrome开发者工具面板 F12 调试大全 记录
面板上包含了Elements面板.Console面板.Sources面板.Network面板.Timeline面板.Profiles面板.Application面板.Security面板.Audits ...
- js 获取dom 为null 测试
<!DOCTYPE html> <html> <head> </head> <body> <h1> 这是H1 </h1&g ...
- 【知识】定时器setTimeout/setInterval执行时this指针指向问题
[问题描述] setTimetout/setInterval中this指针指向window,以下是一个小demo: var demoChange = { key: true, changeFun() ...
- 文本框——EditText
长度
- 使用 nodejs 和 axios 以及 cherrio 爬取天气预报
安装依赖 引入依赖 发送请求 解析请求的返回值 以下代码可以复制直接运行,获得 7 天的天气预报 const axios = require('axios') const cheerio = requ ...
- Selenium 三种等待方式详解
我们在做WEB自动化时,一般要等待页面元素加载完成后,才能执行操作,否则会报找不到元素的错误,这样就要求我们在有些场景下加等待时间. 我们平常用到的有三种等待方式: 强制等待 隐式等待 显示等待 一. ...
- shell基础练习题
shell 基础练习题 1.编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小 #!/bin ...
- maven 私服的setting.xml配置
<?xml version="1.0" encoding="UTF-8"?> 2 <settings xmlns="http://m ...
- LeetCode_1114.按顺序打印(多线程)
LeetCode_1114 LeetCode-1114.按顺序打印 我们提供了一个类: public class Foo { public void one() { print("one&q ...
- linux测试某进程占用oi、cpu、内存的使用情况
pidstat 概述 pidstat是sysstat工具的一个命令,用于监控全部或指定进程的cpu.内存.线程.设备IO等系统资源的占用情况.pidstat首次运行时显示自系统启动开始的各项统计信息, ...