关注
小弟的😁 import java.util.HashMap;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
for (int i = 0; i < n; i++) {
int nodes = in.nextInt();
HashMap<Integer, Pair> map = new HashMap<>();
int[] depth = new int[nodes];
for (int j = 0; j < nodes; j++) {
Pair pair = new Pair(in.nextInt(), in.nextInt(), in.nextInt());
map.put(j, pair);
update(depth, map, pair.left, j);
update(depth, map, pair.right, j);
}
int maxDepth = Integer.MIN_VALUE;
for (int j = 0; j < nodes; j++) {
maxDepth = Math.max(maxDepth, depth[j]);
}
int[] lines = new int[maxDepth + 1];
for (int j = 0; j < nodes; j++) {
lines[depth[j]] += map.get(j).weight;
}
boolean flag = false;
for (int j = 1; j <= maxDepth; j++) {
if (lines[j] <= lines[j - 1]) {
flag = true;
break;
}
}
System.out.println(flag ? "NO" : "YES");
}
}
private static void update(int[] depth, HashMap<Integer, Pair> map, int cur, int root) {
if (cur == -1) {
return;
}
depth[cur] = depth[root] + 1;
if (map.containsKey(cur)) {
Pair pair = map.get(cur);
update(depth, map, pair.left, cur);
update(depth, map, pair.right, cur);
}
}
}
class Pair {
int weight = 0;
int left = -1;
int right = -1;
public Pair(int weight, int left, int right) {
this.weight = weight;
this.left = left;
this.right = right;
}
}
查看原帖
点赞 评论
相关推荐
牛客热帖
更多
正在热议
更多
# 2025年终总结 #
167587次浏览 2829人参与
# 找工作,行业重要还是岗位重要? #
84872次浏览 1679人参与
# 你面试体验感最差/最好的公司 #
13799次浏览 225人参与
# 一人说一个提前实习的好处 #
8514次浏览 176人参与
# 今年你最想重开的一场面试是? #
2898次浏览 56人参与
# 秋招落幕,你是He or Be #
8112次浏览 174人参与
# 重来一次,你会对开始求职的自己说 #
5327次浏览 134人参与
# 实习没事做是福还是祸? #
13983次浏览 217人参与
# 职场上哪些行为很加分? #
305640次浏览 3438人参与
# 大家每天通勤多久? #
68644次浏览 432人参与
# 团建是“福利”还是是 “渡劫” #
6321次浏览 141人参与
# 你小心翼翼的闯过多大的祸? #
10344次浏览 148人参与
# 比亚迪工作体验 #
73713次浏览 279人参与
# 大厂VS公务员你怎么选 #
73909次浏览 677人参与
# 工作中听到最受打击的一句话 #
4934次浏览 86人参与
# 大家实习每天都在干啥 #
106256次浏览 573人参与
# 如何排解工作中的焦虑 #
247547次浏览 2281人参与
# 长城汽车工作体验 #
12901次浏览 16人参与
# 机械人避雷的岗位/公司 #
38598次浏览 261人参与
# 秋招结束之后的日子 #
114135次浏览 1052人参与
曼迪匹艾公司福利 124人发布
