一开始要符合题目条件, 那么肯定没有任何一个点是孤立的, 也就是说没有点的度数是1

所以我就想让度数是1的叶子节点相互连起来。然后WA
然后看这哥们的博客

https://blog.csdn.net/trote_w/article/details/79504280

原来连叶子的时候, 有三个叶子的时候, 中间的留到下一次连,左右连起来。

我之前是直接按照顺序连。

按照顺序那么边可能会封闭在一颗子树里面, 比如一颗子树有两个叶子 ,然后他们互相连接。

这个时候把 子树的根 和 子树的根的父亲连的边切断, 这一颗子树就分离出来了, 就不联通了。

如果是中间留下连两边的话, 这样可以保证当前子树添加的边不是封闭的, 是可以有边连到

外面去的, 也就是说可以从当前子树的叶子连接到其他子树的叶子上, 这样即使把子树的根 和 子树的根的父亲连的边切断

还是有边连出去的, 就不会不联通了。

这样三个三个一组来连, 然后到最后有三种情况。

因为前面已经连完了, 就可以等价于只剩下树根和剩下的叶子节点。

也就是说可以看成一个根节点下连着0~2个叶子。

以下讨论都看成是这样, 那么就很好想了。


(1)叶子数是三的倍数, 刚好连完。这个时候就over了, 可以输出答案了。

(2)叶子数是三的倍数+1, 也就是最后剩下一个叶子, 那么把这个叶子和树根连接。

(3)叶子数是三的倍数加2, 也就是说剩下两个叶子, 那么把两个叶子互相连接。


另外UVa 1670数据有问题, 去Uvalive 5920提交


#include<cstdio>
#include<vector>
#define REP(i, a, b) for(int i = (a); i < (b); i++)
using namespace std; const int MAXN = 112345;
vector<int> g[MAXN], leaf;
vector<pair<int, int> > ans;
int n, root; int dfs(int u, int fa)
{
REP(i, 0, g[u].size())
{
if(g[u][i] == fa) continue;
dfs(g[u][i], u);
} if(g[u].size() == 1) //叶子节点
{
leaf.push_back(u);
if(leaf.size() == 3) //左右连, 中间留下
{
int t = leaf[1];
ans.push_back(make_pair(leaf[0], leaf[2]));
leaf.clear();
leaf.push_back(t);
}
}
} int main()
{
while(~scanf("%d", &n))
{
REP(i, 1, n + 1) g[i].clear();
REP(i, 0, n - 1)
{
int u, v;
scanf("%d%d", &u, &v);
g[u].push_back(v); g[v].push_back(u);
if(g[u].size() > 1) root = u; //找度数大于1的做树根
if(g[v].size() > 1) root = v;
} leaf.clear(); ans.clear();
dfs(root, -1); if(leaf.size() == 2) ans.push_back(make_pair(leaf[0], leaf[1])); //最后剩下的节点,见前面的解析。
else if(leaf.size() == 1) ans.push_back(make_pair(root, leaf[0])); printf("%d\n", ans.size());
REP(i, 0, ans.size()) printf("%d %d\n", ans[i].first, ans[i].second);
} return 0;
}


不好想


紫书 习题 11-17 UVa 1670 (图论构造)的更多相关文章

  1. 紫书 习题 11-9 UVa 12549 (二分图最小点覆盖)

    用到了二分图的一些性质, 最大匹配数=最小点覆盖 貌似在白书上有讲 还不是很懂, 自己看着别人的博客用网络流写了一遍 反正以后学白书应该会系统学二分图的,紫书上没讲深. 目前就这样吧. #includ ...

  2. 紫书 习题 11-8 UVa 1663 (最大流求二分图最大基数匹配)

    很奇怪, 看到网上用的都是匈牙利算法求最大基数匹配 紫书上压根没讲这个算法, 而是用最大流求的. 难道是因为第一个人用匈牙利算法然后其他所有的博客都是看这个博客的吗? 很有可能-- 回归正题. 题目中 ...

  3. 紫书 习题8-12 UVa 1153(贪心)

    本来以为这道题是考不相交区间, 结果还专门复习了一遍前面写的, 然后发现这道题的区间是不是 固定的, 是在一个范围内"滑动的", 只要右端点不超过截止时间就ok. 然后我就先考虑有 ...

  4. 紫书 习题8-7 UVa 11925(构造法, 不需逆向)

    这道题的意思紫书上是错误的-- 难怪一开始我非常奇怪为什么第二个样例输出的是2, 按照紫书上的意思应该是22 然后就不管了,先写, 然后就WA了. 然后看了https://blog.csdn.net/ ...

  5. 紫书 习题 11-15 UVa 1668 (图论构造法)

    参考了http://www.bubuko.com/infodetail-1276416.html 首先是逆向思维, 向把每条边看作一条路径, 然后再去合并 然后我们讨论怎么样合并时最优的 我们讨论当前 ...

  6. 紫书 习题 11-10 UVa 12264 (二分答案+最大流)

    书上写的是UVa 12011, 实际上是 12264 参考了https://blog.csdn.net/xl2015190026/article/details/51902823 这道题就是求出一种最 ...

  7. 紫书 习题 10-13 UVa 11526(打表找规律+分步枚举)

    首先看这道题目,我预感商数肯定是有规律的排列的,于是我打表找一下规律 100 / 1 = 100 100 / 2 = 50  100 / 3 = 33  100 / 4 = 25  100 / 5 = ...

  8. UVA 1594 Ducci Sequence(紫书习题5-2 简单模拟题)

    A Ducci sequence is a sequence of n-tuples of integers. Given an n-tuple of integers (a1, a2, · · · ...

  9. 紫书 习题7-8 UVa 12107 (IDA*)

    参考了这哥们的博客 https://blog.csdn.net/hyqsblog/article/details/46980287  (1)atoi可以char数组转int, 头文件 cstdlib ...

随机推荐

  1. [剑指offer] 14. 链表中倒数第K个节点+翻转+逆序打印+合并两个排序链表 + 链表相交(第一个公共节点) (链表)

    题目描述 输入一个链表,输出该链表中倒数第k个结点. 思路:  两个指针,起始位置都是从链表头开始,第一个比第二个先走K个节点,当第一个走到链表尾时,第二个指针的位置就是倒数第k个节点.(两指针始终相 ...

  2. (转载)springboot集成httpinvoker的客户端

    原文:https://blog.csdn.net/geanwan/article/details/51505679 由于新项目采用了springboot,需要调用之前远程服务(之前项目用的spring ...

  3. Mybatis 中 foreach collection 的三种用法

    foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach元素的属性主要有 item,index,collection,open,separator,close. ...

  4. Image Processing for Very Large Images

    The key idea here is the partial image descriptor VIPS(VASARI Image Processing System) 是近几年逐渐兴起的针对大图 ...

  5. ASP.NET-Router配置中MapRoute的参数

    App_Start文件夹中的RouteConfig MapRoute(string name,string url); MapRoute(string name,string url,object d ...

  6. java判断string数组中是否包含某个元素

  7. Java线程演示样例 - 继承Thread类和实现Runnable接口

    进程(Process)和线程(Thread)是程序执行的两个基本单元. Java并发编程很多其它的是和线程相关. 进程 进程是一个独立的执行单元,可将其视为一个程序或应用.然而,一个程序内部同事还包括 ...

  8. hdoj 1013Digital Roots

     /*Digital Roots Problem Description The digital root of a positive integer is found by summing th ...

  9. 从ORA-27300,ORA-27301到ORA-00064

        近期因为session数量添加,须要调整session,也就是要调整process參数. 看是比較简单的一个问题,却遭遇了ORA-27300,ORA-27301.因为这个涉及到了有关内核參数k ...

  10. BZOJ 1057: [ZJOI2007]棋盘制作 悬线法求最大子矩阵+dp

    1057: [ZJOI2007]棋盘制作 Description 国际象棋是世界上最古老的博弈游戏之一,和中国的围棋.象棋以及日本的将棋同享盛名.据说国际象棋起源于易经的思想,棋盘是一个8*8大小的黑 ...