A41046.【树形动态规划】Ksyusha and Chinchilla

普及+/提高

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

Ksyusha有一只宠物龙猫、一棵有 nn 个顶点的树和巨大的剪刀。一棵树是一个没有循环的连接图。在一节枯燥的物理课上,Ksyusha想到了如何逗她的宠物开心。

宠物龙猫喜欢玩树枝。一个树枝是一棵有3个顶点的树。

该树枝看起来像这样。

切割是指去除树上的一些(尚未切割的)边缘。Ksyusha有大量的空闲时间,所以她能负担得起足够多的切割,从而使树分裂成分支。换句话说,经过几次(可能是零)切割后,每个顶点必须正好属于一个分支。

帮助Ksyusha选择要切割的边,或者告诉他这是不可能的。

输入格式

第一行包含一个整数 nn (2≤n≤2*10510^5),表示树中顶点的数量。

接下来的 n1n-1行,表示 n1n-1 条边。

每一行有两个整数 uiu_iviv_i ,表示第 ii 条边。 (1≤ui,u_i, viv_i≤n)

可以保证这组边形成一棵树。

输出格式

如果所需的切树方式不存在,输出 1-1

否则,输出一个整数 kk,表示要切割的边的数量。

输入输出样例

  • 输入#1

    9
    1 2
    4 3
    7 9
    5 4
    4 6
    3 2
    8 7
    1 7

    输出#1

    2
  • 输入#2

    5
    1 3
    5 3
    5 2
    3 4

    输出#2

    -1

说明/提示

第一个测试样例:可以删除第 22 条边和第 88 条边。

首页