AT_abc133_e [ABC133E] Virus Tree 2

题目描述

给定一棵有 $N$ 个顶点、$N-1$ 条边的树。顶点编号为 $1,2,\ldots,N$,第 $i$ 条边连接顶点 $a_i$ 和 $b_i$。 你有 $K$ 种颜色的颜料。你需要给树的每个顶点选择一种颜色进行涂色,要求满足以下条件: - 对于任意两个距离不超过 $2$ 的不同顶点 $x,y$,顶点 $x$ 和顶点 $y$ 的颜色必须不同。 请计算有多少种不同的涂色方法。将结果对 $1,000,000,007$ 取模后输出。 **关于树** 树是一种特殊的图。详情请参考:[Wikipedia「木 (数学)」](https://ja.wikipedia.org/wiki/%E6%9C%A8_(%E6%95%B0%E5%AD%A6))。 **关于距离** 两个顶点 $x,y$ 之间的距离是指从 $x$ 到 $y$ 需要经过的最少边数。

输入格式

输入通过标准输入按以下格式给出: > $N$ $K$ > $a_1$ $b_1$ > $a_2$ $b_2$ > $\cdots$ > $a_{N-1}$ $b_{N-1}$

输出格式

输出树的所有合法涂色方法数,对 $1,000,000,007$ 取模后的结果。

说明/提示

### 限制条件 - $1 \leq N,K \leq 10^5$ - $1 \leq a_i,b_i \leq N$ - 输入保证给定的图是一棵树。 ### 样例解释 1 ![zu](https://img.atcoder.jp/ghi/491cd56a53e99ba7677ee4827b8f767a.png) 共有 $6$ 种不同的涂色方法。 由 ChatGPT 4.1 翻译