bzoj 2503 相框——思路
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2503
我也知道应该只关注度数。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=,M=;
int n,m,deg[N],sum,ans;
int main()
{
scanf("%d%d",&n,&m);int x,y;
for(int i=;i<=m;i++)
{
scanf("%d%d",&x,&y);
deg[x]++;deg[y]++;
sum+=(!deg[x])+(!deg[y]);//焊接
}
for(int i=;i<=n;i++)
{
if(deg[i]>)ans+=deg[i]/-+(deg[i]&);//烧熔
sum+=(deg[i]&);//焊接
}
printf("%d",ans+(sum>>));
return ;
}
秒WA
应该仔细读题,那个不用deg[ i ]/2 - 1 + (deg[ i ] & 1),一次就能焊好;
而且还没管不同连通块。
TJ:http://www.cnblogs.com/TSHugh/p/7617699.html
需要记一下一个连通块里有没有奇度数的点,因为对于没有的要手动熔断。这时要特判是不是只有一个连通块。
学习TJ代码:https://blog.csdn.net/PoPoQQQ/article/details/48031135
终于发现一次就能把一个点熔好了。还记录了一个连通块有没有被熔过。就因为一次也能顺便熔出两个奇度数点,所以对于没有奇度数点的连通块要通过这个判断是否需要再熔一次。
还学习了TJ的好写法:读入的时候不用区分0的端点什么的,++n就好了!仔细想一想是等价的。
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=,M=5e4+;
int n,m,deg[N],fa[N],jd,ans,yf,cnt;
bool tag[N],cz[N];
int find(int a){return fa[a]==a?a:fa[a]=find(fa[a]);}
int main()
{
scanf("%d%d",&n,&m);int x,y;
for(int i=;i<=m;i++)
{
scanf("%d%d",&x,&y);
if(!x)x=++n;if(!y)y=++n;//!!!
deg[x]++;deg[y]++;fa[find(x)]=find(y);
// if(!x&&!y)jd+=2;
// else if(x&&y)deg[x]++,deg[y]++,fa[find(x)]=find(y);
// else{
// jd++;if(x)deg[x]++;if(y)deg[y]++;
// }
}
for(int i=;i<=n;i++)
{
if(deg[i]&)jd++,tag[find(i)]=;
if(deg[i]>)ans++,cz[find(i)]=;//记录cz!//一次就能熔好!!!!!
if(deg[i]&&fa[i]==i)cnt++;//deg[i]!!
}
if(cnt==&&!jd){printf("0\n");return ;}
for(int i=;i<=n;i++)
if(fa[i]==i&&!tag[i]&&cnt>)
{
if(!cz[i])ans++;
jd+=;//&&cnt>1!
}
printf("%d\n",ans+(jd>>));
return ;
}
秒WA
再次学习(抄)了一遍。
别忘了到处判断deg[ i ]!!!别忘了把数组调大,赋 fa[ ] 的时候也要调大范围!
虽然A了可是一点也不高兴怎么办……
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=,M=5e4+,Lm=1e5+1e3+;;
int n,m,deg[Lm],fa[Lm],jd,ans,cnt;
bool tag[Lm],cz[Lm];
int find(int a){return fa[a]==a?a:fa[a]=find(fa[a]);}
int main()
{
scanf("%d%d",&n,&m);int x,y;
for(int i=;i<=Lm-;i++)fa[i]=i;
for(int i=;i<=m;i++)
{
scanf("%d%d",&x,&y);
if(!x)x=++n;if(!y)y=++n;//!!!
deg[x]++;deg[y]++;fa[find(x)]=find(y);
// if(!x&&!y)jd+=2;
// else if(x&&y)deg[x]++,deg[y]++,fa[find(x)]=find(y);
// else{
// jd++;if(x)deg[x]++;if(y)deg[y]++;
// }
}
for(int i=;i<=n;i++)
{
if(deg[i]&)jd++,tag[find(i)]=;
if(deg[i]>)ans++,cz[find(i)]=;//记录cz!//一次就能熔好!!!!!
if(deg[i]&&find(i)==i)cnt++;//deg[i]!!
}
// if(cnt==1&&!jd){printf("0\n");return 0;}
for(int i=;i<=n;i++)
if(deg[i]&&find(i)==i&&!tag[i]&&cnt>)//deg[i]!!!
{
if(!cz[i])ans++;
jd+=;//&&cnt>1!
}
printf("%d\n",ans+(jd>>));
return ;
}
bzoj 2503 相框——思路的更多相关文章
- bzoj 2503 相框 分类讨论
题目大意:给定一张无向图,每次可以进行以下两种操作: 1.将一个点分裂成一些点,原先这个点连接的每条边任选一个新点进行连接 2.将两个度数为1的点合并为1个点 求将这个图变成一个环的最小操作次数 我们 ...
- 【BZOJ 2503】相框 图论+讨论
这道题目就是考验了一下图论基本知识与对可爱的代码实现的应对能力. 我们先分析题干信息.我们要形成相框,那么所有的点的度为2(参与的点),那么所有度大于2的点都需要熔断,而且一次完成所有关于这个点的熔断 ...
- bzoj2503 相框——思路
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2503 思路题: 首先,这种问题应该注意到答案只跟度数有关,跟其他什么连接方法之类的完全无关: ...
- bzoj 2151 种树 —— 思路+链表
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2151 先都放进堆里取最大的,但选了一个就不能选它两边的,所以可能不是最优,要有“反悔”的措施 ...
- 【BZOJ-2503】相框 并查集 + 分类讨论
2503: 相框 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 71 Solved: 31[Submit][Status][Discuss] Desc ...
- BZOJ.2006.[NOI2010]超级钢琴(贪心 堆)
BZOJ 洛谷 思路和BZOJ3784一样,用前缀和+堆维护.做那题吧,不赘述啦. (没错我就是水一个AC) //54620kb 1060ms #include <queue> #incl ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- bzoj [SDOI2014]数表 莫比乌斯反演 BIT
bzoj [SDOI2014]数表 莫比乌斯反演 BIT 链接 bzoj luogu loj 思路 \[ \sum\limits_{i=1}^{n}\sum\limits_{j=1}^{m}a*[f[ ...
- [HNOI2012][BZOJ2732] 射箭 [二分+半平面交]
题面 BZOJ题面 思路 半平面交代码讲解戳这里,用的就是这道题 我们射箭的函数形如$y=Ax^2+Bx$ 考虑每一个靶子$(x_0,y_1,y_2)$,实际上是关于$A,B$的不等式限制条件 我们只 ...
随机推荐
- TortoiseGit可能遇到Permission denied (publickey).
1.检测是不是没设置公钥和私钥 2.公钥有没有添加到git账户里面去 3.检测如下图路径正确不正确
- Python全栈开发:css引入方式
css的四种引入方式: 1.行内式 行内式是在标记的style属性中设定CSS样式.这种方式没有体现出CSS的优势,不推荐使用. <p style="color: red;backgr ...
- DataTime 和 时间转化
如果知道tostring 的字符串格式那么可以根据字符串格式转化成 DateTime string timeText = DateTime.Now.ToString("yy/MM/dd HH ...
- position:fixed失效问题
fixed定位的元素,如果父级有transform样式,值不为none,那么fixed定位就会失效. 解决方法:使用transform样式的元素,不要包含fixed定位的子元素.
- Ubuntu 12.04 Eclipse设置 Javadoc背景色
在Ambiance主题下,eclipse弹出的tip是黑色背景的,这样压根就看不清java doc. 当然可以在外观改变系统主题为其他主题,相应的gtk-2.0/gtkrc要重新设置,比如Ubuntu ...
- [洛谷P2472] [SCOI2007]蜥蜴
题目链接: 蜥蜴 题目分析: 一道网络流,先来分析一下问题: 在一个\(r*c\)的图中分布了一些数,其他地方都用\(0\)填充,我们分别从指定的一些数出发,每次可以移动到周围距离为\(d\)以内的数 ...
- JDK源码阅读--Hashtable
public class Hashtable<K,V> extends Dictionary<K,V> implements Map<K,V>, Cloneable ...
- bean的使用
前言 Spring最基础的功能就是一个bean工厂,所以本文讲解的是Spring生成bean的种种方法及细节,Spring配置文件的名字是bean.xml,定义几个类: 一个Person类: publ ...
- codeforces 1129A2-Toy Train
传送门:QAQQAQ 题意:有1-n个站点,成环形,有一辆运货车,在这个n个站点之间运输糖果,货车只能按照1->n的方向走,到第n个站的时候,又回到的1,现在告诉你有m个运输任务,从x站点运输一 ...
- PAT甲级——A1092 To Buy or Not to Buy【20】
Eva would like to make a string of beads with her favorite colors so she went to a small shop to buy ...