回文树
Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 512000/512000 K (Java/Others)
Total Submission(s): 231 Accepted Submission(s): 54
Problem Description
给定一棵n个点的树,任意两点之间有且仅有一条直接或间接路径。这些点编号依次为1到n,其中编号为i的点上有一个正整数ai。你可以认为每个数ai都是在[1,n]里等概率随机挑选的。
令S(u,v)表示在树上u到v的唯一最短路径上,按照离u从近到远依次考虑每个点,将它们上面的数字a按顺序写下连成的字符串。若一个字符串正着读和倒着读相等,则称它为回文串,比如1 2 1和1 3 3 1是回文串,但是1 21不是回文串。
请写一个程序,统计有多少个正整数对(u,v)满足1≤u≤v≤n,且S(u,v)是回文串。
Input
第一行包含一个正整数T(1≤T≤20),表示测试数据的组数。
每组数据第一行包含一个正整数n(1≤n≤100000),表示点数。