csps模拟85表达式密码,电压机制,括号密码题解
题面:https://www.cnblogs.com/Juve/articles/11733280.html
表达式密码:
是个水题。。。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=1e5+;
int len,fh=;
char s[MAXN];
signed main(){
//freopen("expression.in","r",stdin);
//freopen("i.out","w",stdout);
scanf("%s",s+);
len=strlen(s+);
s[len+]='?';
if(s[]=='-') fh=;
else fh=;
for(int i=;i<=len;){
while(i<=len&&s[i]<''||s[i]>'') ++i;
if(fh==){
putchar('-');
putchar(s[i]);
++i;
if(s[i]=='-') fh=;
else fh=;
}else{
while(i<=len&&s[i]==''){
putchar('+');
putchar('');
++i;
}
if(s[i]=='-') fh=;
else if(s[i]=='+') fh=;
else if(s[i]!='?'){
if(i!=) putchar('+');
while(i<=len&&s[i]>=''&&s[i]<=''){
putchar(s[i]);
++i;
}
if(s[i]=='-') fh=;
else fh=;
}
}
}
puts("");
return ;
}
电压机制:
题目翻译:在一张无向图上,有多少边满足:在所有的奇环上但是不再任何一个偶环上
题目给了基环树的数据,启发我们想到正解
如过那个环是偶环,那么答案就是环外的,如果是奇环,答案就是环内的
考虑如何拓展到一般情况
我们dfs时会建出一个搜索树,我们把新树建出来,同时记录每一条边是否为树边
然后扫每一个不是树边的边,如果把它加进新图,就会形成环,因为是在树上,lca,两点间dis很好求,所以我们知道加入这条边会形成奇环还是偶环
暴力排除每一条边显然不可能,我们考虑差分
把每一条边放到点,统计每一个点被多少个奇环或偶环经过,打差分,最后dfs一遍就统计出了一个点在几个奇环,几个偶环中了
然后就统计出答案了,注意根节点不要统计,因为把边放到点,没有边被放到了根节点
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define re register
using namespace std;
const int MAXN=1e5+5;
int n,m,ans=0,f[MAXN],g[MAXN],tot=0;
int to[MAXN<<1],nxt[MAXN<<1],id[MAXN<<1],pre[MAXN],cnt=0;
struct node{
int u,v;
bool flag;//shifoushishubian
}e[MAXN<<1];
inline void add(re int u,re int v){
++cnt,to[cnt]=v,nxt[cnt]=pre[u],pre[u]=cnt;
}
int fa[MAXN];
inline int find(re int x){
return fa[x]=(fa[x]==x?x:find(fa[x]));
}
int deep[MAXN],siz[MAXN],son[MAXN];
inline void dfs(re int x){
siz[x]=1;
for(re int i=pre[x];i;i=nxt[i]){
re int y=to[i];
if(y==fa[x]) continue;
fa[y]=x;deep[y]=deep[x]+1;
dfs(y);
siz[x]+=siz[y];
if(siz[son[x]]<siz[y]) son[x]=y;
}
}
int top[MAXN];
inline void DFS(re int x,re int topf){
top[x]=topf;
if(son[x]) DFS(son[x],topf);
for(re int i=pre[x];i;i=nxt[i]){
re int y=to[i];
if(y==fa[x]||y==son[x]) continue;
DFS(y,y);
}
}
inline int LCA(re int x,re int y){
while(top[x]!=top[y]){
if(deep[top[x]]<deep[top[y]]) swap(x,y);
x=fa[x];
}
if(deep[x]>deep[y]) swap(x,y);
return x;
}
bool vis[MAXN];
void dfs1(int x,int rt){
vis[x]=1;
for(int i=pre[x];i;i=nxt[i]){
int y=to[i];
if(y==fa[x]) continue;
dfs1(y,rt);
g[x]+=g[y],f[x]+=f[y];
}
if(f[x]==tot&&g[x]==0&&x!=rt) ++ans;
}
signed main(){
scanf("%d%d",&n,&m);
for(re int i=1;i<=n;++i) fa[i]=i;
for(re int i=1,u,v;i<=m;++i){
scanf("%d%d",&u,&v);
e[i]=(node){u,v,0};
}
re int num=0;
for(re int i=1;i<=m;++i){
re int x=find(e[i].u),y=find(e[i].v);
if(x!=y){
fa[x]=y;
add(e[i].u,e[i].v),add(e[i].v,e[i].u);
e[i].flag=1;
++num;
if(num==n-1) break;
}
}
memset(fa,0,sizeof(fa));
for(int i=1;i<=n;++i){
if(deep[i]) continue;
deep[i]=1;
dfs(i),DFS(i,i);
}
for(re int i=1;i<=m;++i){
if(e[i].flag) continue;
re int x=e[i].u,y=e[i].v;
re int lca=LCA(x,y);
re int dis=deep[x]+deep[y]-deep[lca]*2;
if(dis&1){//ouhuan
++g[x],++g[y],g[lca]-=2;
}else{
++tot;
++f[x],++f[y],f[lca]-=2;
}
}
for(int i=1;i<=n;++i){
if(vis[i]) continue;
dfs1(i,i);
}
if(tot==1) ++ans;
printf("%d\n",ans);
return 0;
}
括号密码:不会
csps模拟85表达式密码,电压机制,括号密码题解的更多相关文章
- [CSP-S模拟测试]:表达式密码(模拟)
题目传送门(内部题87) 输入格式 从文件$expression.in$中读入数据.输入一行,一个字符串$S$,表示原表达式,保证为合法表达式 输出格式 输出到文件$expression.out$中. ...
- CSPS模拟 85
WWB大佬的bitset映射真是太强了! %%% T1 观察样例,猜规律. T2 对题目的翻译工作用了很长时间 翻译错了好几次.. 观察到奇环没法染色,选的边必须把奇环弄断 如果在偶环上,偶环就变得没 ...
- csps模拟92数列,数对,最小距离题解
题面:https://www.cnblogs.com/Juve/articles/11767225.html 数列: 简化题意:已知a,b,c,求满足$a*x+b*y=c$的$x+y$最小值 然后ex ...
- csp-s模拟65Simple,Walk, Travel,棋盘题解
题面:https://www.cnblogs.com/Juve/articles/11639923.html simple: 考试时只想到的暴力exgcd判断 考虑n,m互质的情况: 我们枚举y,对于 ...
- csp-s模拟测试55 联,赛,题题解
题面:https://www.cnblogs.com/Juve/articles/11610969.html 联: 用线段树维护区间和,要修改成1或0就线段树修改区间和 如果是异或,那么新的区间和就是 ...
- [CSP-S模拟测试]:括号密码(贪心)
题目描述 在“无限神机”的核心上,有一个奇怪的括号密码,密码初始已经有一个括号序列,有$n$个限制条件,每个限制条件描述为$l_i$和$r_i$,表示区间$[l_i,r_i]$的括号序列必须合法.调整 ...
- csp-s模拟测试85
csp-s模拟测试85 $T1$全场秒切没有什么区分度,$T2$全场成功转化题意但是我并不会打,$T3$暴力都没打很遗憾. 100 00:21:49 02:56:35 02:56:49 135 02: ...
- 【例题收藏】◇例题·6◇ 电压机制(voltage)
◆例题·6◆ 电压机制 周六日常模拟赛……已经不知道该说什么了(感觉做不出来的都是好题) ▷ 题目 (终于不用自己翻译英文题了╮(╯-╰)╭) [问题描述] 科学家在“无限神机”(Infinity M ...
- csp-s模拟测试83(集训过半)
csp-s模拟测试83(集训过半) 一场信心赛.起初$OJ$爆了我就看见全场$A$了$T1$并且夹杂着$A$掉$T2$我就很难受. 这场比赛没有深入思考,很失败,一个多小时后就结束了我罪恶的一生. 0 ...
随机推荐
- GitHub排名TOP30的机器学习开源项目
对于机器学习者来说,阅读开源代码并基于代码构建自己的项目,是一个非常有效的学习方法.看看以下这些Github上平均star为3558的开源项目,你错了哪些? 1. FastText:快速文本表示和文本 ...
- Centos 添加 sudo 用户
说明以下的 <username>字样 是 用户名 新增用户 # 终端命令 useradd <username> 举例: useradd <username> -s ...
- vue 学习二 深入vue双向绑定原理
vue双向绑定原理 请示总体来讲 就是为data的中的每个属性字段添加一个getter/seter属性 以此来追踪数据的变化,而执行这部操作,依赖的就是js的Object.defineProperty ...
- 5. java运算符
1.算术运算符 注意: % 取余数 (1)自增 (++)前自增:先自增完毕,再运算整个表达式,语句分号前面的都是运算表达式: 后自增,先运算完整个表达式(分号前面的都是表达式),再进行自增: 2.赋值 ...
- Python自学:第四章 复制列表(1)
# -*- coding: GBK -*- my_foods = ['pizza', 'falafel', 'carrot cake'] friend_foods = my_foods[:] prin ...
- Batch - FOR /F Delims 和 Tokens 用法
原文地址: for /f命令之—Delims和Tokens用法&总结 作者:别逗了好么 在For命令语踞饽参数F中,最难理解的就是Delims和Tokens两个选项,本文简单的做一个比较和总拮 ...
- Android Studio Download
{ https://developer.android.google.cn/studio }
- 查看hadoop压缩方式
bin/hadoop checknative 来查看我们编译之后的hadoop支持的各种压缩,如果出现openssl为false,那么就在线安装一下依赖包 bin/hadoop checknativ ...
- NX二次开发-UFUN获取环境变量路径,将环境变量转换为字符串,字符串拼接UF_translate_variable
NX9+VS2012 #include <uf.h> UF_initialize(); //UFUN获取环境变量路径 //将环境变量转换为字符串 char* GetName = NULL; ...
- (转)实现这两个接口ModelDriven<T>,Preparable有什么用?
转:http://www.cnblogs.com/guanghuiqq/archive/2012/08/24/2654300.html 实现了ModelDriven就必须实现getModel这个方法, ...