临近$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. python中的文件读取

    ---恢复内容开始--- r模式,只读模式,不可写入,文件不存在会报错 #r模式,能读不能写,文件不存在会报错 f = open('a1.txt')#不写'r',默认只读 result = f.rea ...

  2. PHP基础-表达式介绍

    表达式是 PHP 最重要的基石.在PHP 编程 中,几乎所写的任何东西都是一个表达式.简单但却最精确的定义一个表达式的方式就是“任何有值的东西”. 最基本的表达式形式是常量和变量.当键入“$a = 5 ...

  3. BZOJ 3162: 独钓寒江雪 树的同构 + 组合 + 计数

    Description Input   Output 求一棵树编号序列不同的方案数: 令 $f[u],g[u]$ 分别表示 $u$ 选/不选 的方案数. 则 $f[u]=\prod_{v\in son ...

  4. [CSP-S模拟测试]:取石子(博弈论+DP)

    题目描述 有三堆石子,它们的石子个数分别为$x,y,z$.$A$和$B$正在博弈,由$A$先手,双方轮流操作.每次操作是指,选择若干堆($1-3$堆)石子,从中各取出相同数量的石子(不能$1$个都不取 ...

  5. 关于项目中的一些经验:封装activity、service的基类,封装数据对象

    经验一,将几个页面公用的数据,和方法进行封装,形成一个baseActivity的类: package com.ctbri.weather.control; import java.util.Array ...

  6. json根据一个值返回对象,filter方法使用

    d = {   "student":[     {       "count":1000,       "stuList":[        ...

  7. VC程序禁用提示框

    程序需要24小时不中断 如果错误提示了的话 runtime error 监控程序就不能重启 下面是网上找的 方便以后用到 http://blog.csdn.net/yuzhiyuxia/article ...

  8. rtmp协议分析

    最近需要做一个rtmp服务器,着手分析一下rtmp协议,开干. rtmp握手 这个推荐一篇文章讲解得比较透彻http://blog.sina.com.cn/s/blog_676e11660102v8b ...

  9. Spring boot 自定义一个starter pom

    用过springboot的自动配置会觉得非常方便,我们完全可以自己写一个starter pom,这样不仅可以有自动配置功能,而且具有更通用的的耦合度低的配置, 新建一个starter的maven项目, ...

  10. nginx调优buffer参数设置

    内容来自 https://blog.tanteng.me/2016/03/nginx-buffer-params/.有空再详细了解 Nginx性能调优之buffer参数设置 打开Nginx的error ...