T1: 可被3整数的偶数的平均值

思路:数组遍历

被3整数的偶数 \(\Leftrightarrow\) 被6整数的数

public int averageValue(int[] nums) {
int sum = 0;
int count = 0;
for (int num : nums) {
if (num % 6 == 0) {
sum += num;
count += 1;
}
} if (count == 0) {
return 0;
} return sum / count;
}

T2: 最流行的视频创作者

思路:数组遍历 + 哈希

key: 对应创作者

value: 对应一个列表,list.get[0]表示创作者视频流量总和,list.get[1]表示创作者单个视频流量最大值,list.get[3] 表示创作者单个视频流量最大值对应的id

public List<List<String>> mostPopularCreator(String[] creators, String[] ids, int[] views) {
Map<String, List<String>> map = new HashMap<>(); long maxValue = 0;
for (int i = 0; i < creators.length; ++i) {
if (!map.containsKey(creators[i])) {
maxValue = Math.max(maxValue, views[i]);
List<String> list = new ArrayList<>();
list.add(String.valueOf(views[i]));
list.add(String.valueOf(views[i]));
list.add(ids[i]); map.put(creators[i], list);
}
else {
List<String> list = map.get(creators[i]); long sum = Long.valueOf(list.get(0));
int max = Integer.valueOf(list.get(1)); sum += views[i];
maxValue = Math.max(maxValue, sum);
if (max < views[i]) {
list.set(2, ids[i]);
max = views[i];
}
else if (max == views[i]) {
if (list.get(2).compareTo(ids[i]) > 0) {
list.set(2, ids[i]);
}
}
list.set(0, String.valueOf(sum)); // 总体流量总和
list.set(1, String.valueOf(max)); // 单个作者最大值 map.put(creators[i], list);
}
} List<List<String>> res = new ArrayList<>();
for (Map.Entry<String, List<String>> entry : map.entrySet()) {
String key = entry.getKey();
List<String> value = entry.getValue(); if (Long.valueOf(value.get(0)) == maxValue) {
List<String> temp = new ArrayList<>();
temp.add(key);
temp.add(value.get(2)); res.add(temp);
}
} return res;
}

T3: 美丽整数的最小增量

思路:贪心

  • 如果低位的值 value 不等于0,则使该为加上 10 - value 产生进位,从而减小数位和
  • 循环向高位贪心直至数位和满足小于等于 target 的要求
public long makeIntegerBeautiful(long n, int target) {
List<Integer> list = new ArrayList<>();
int bitSum = 0;
while (n > 0) {
int temp = (int) (n % 10);
n /= 10; bitSum += temp;
list.add(temp);
} if (bitSum <= target) {
return 0;
} int index = 0;
long ans = 0;
while (bitSum > target) {
int bit = list.get(index);
if (bit == 0) {
index += 1;
continue;
} ans = ans + (long) Math.pow(10, index) * (10 - bit);
index += 1; int temp = index; // 注意:如果左边第一位为9,会循环产生进位
while (temp < list.size() && list.get(temp) == 9) {
list.set(temp, 0);
bitSum -= 9;
temp += 1;
} if (temp == list.size()) {
list.add(1);
}
else {
list.set(temp, list.get(temp) + 1);
}
bitSum = bitSum - bit + 1;
} return ans;
}

T4: 移除子树后的二叉树高度

思路:深度优先搜索

  • 第一次深度优先搜索:计算每个节点的高度值
  • 第二次深度优先搜索:计算去除当前节点为根是子树后,剩余子树的高度值
private Map<TreeNode, Integer> map = new HashMap<>();
private int[] res;
public int[] treeQueries(TreeNode root, int[] queries) {
dfs(root);
map.put(null, 0); res = new int[map.size() + 1];
dfs2(root, -1, 0); for (int i = 0; i < queries.length; ++i) {
queries[i] = res[queries[i]];
} return queries;
} /**
* 第一次DFS: 获取每个节点的高度
* @param node
* @return
*/
private int dfs(TreeNode node) {
if (node == null) {
return 0;
} int height = 1 + Math.max(dfs(node.left), dfs(node.right));
map.put(node, height); return height;
} /**
* 第二次DFS: 删除以当前节点为根的子树后, 剩余子树的最大高度
* @param node: 当前节点
* @param height: 当前节点高度
* @param residue: 去除以当前节点为根的子树的高度
*/
private void dfs2(TreeNode node, int height, int residue) {
if (node == null) {
return;
} height += 1;
res[node.val] = residue; dfs2(node.left, height, Math.max(residue, height + map.get(node.right)));
dfs2(node.right, height, Math.max(residue, height + map.get(node.left)));
}

总结

  • 前3题完成的都挺顺利
  • 第4题思路能想到是 DFS,但是自己每次不同的 query 都去深搜导致超时,没能想到第一遍深搜统计高度值,第二遍深搜计算答案

LeeCode 317周赛复盘的更多相关文章

  1. leecode系列--Two Sum

    学习这件事在任何时间都不能停下.准备坚持刷leecode来提高自己,也会把自己的解答过程记录下来,希望能进步. Two Sum Given an array of integers, return i ...

  2. [codeforces 317]A. Perfect Pair

    [codeforces 317]A. Perfect Pair 试题描述 Let us call a pair of integer numbers m-perfect, if at least on ...

  3. 周赛-KIDx's Pagination 分类: 比赛 2015-08-02 08:23 7人阅读 评论(0) 收藏

    KIDx's Pagination Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) S ...

  4. Win8制作和使用恢复盘

    制作和使用恢复盘要制作恢复盘,请执行以下操作:注:确保计算机连接到交流电源.1. 将指针移至屏幕的右上角或右下角以显示超级按钮,然后单击搜索.2. 根据操作系统的不同,执行以下某项操作:• 在 Win ...

  5. insertion Sort List (链表的插入排序) leecode java

    逻辑简单,代码难写,基础不劳,leecode写注释不能出现中文,太麻烦,我写了大量注释,链表问题最重要的就是你那个指针式干啥的 提交地址https://oj.leetcode.com/problems ...

  6. 后续遍历 java leecode

    以前觉得后续遍历最难写,今天看了篇博客http://blog.csdn.net/sgbfblog/article/details/7773103,其实却是我们仔细比较后续遍历和先序遍历,其实后续遍历就 ...

  7. 非递归实现先序遍历 java leecode 提交

    写完才知道自己学习都是似是而非啊,大家可以也在leecode上提交代码,纯手写,离开eclipse第一种方式:数据结构书上的,使用栈大概思路.1.不断将根节点的左孩子的左孩子直到为空,在这个过程入栈. ...

  8. leecode 归并排序 链表(java)

    写了好久,终于写成了.第一次zai leecode错题,题目质量很高,适合面试,与 1.归并排序是稳定的,在java中 Arrays.sort(a);中对于对象的排序就是归并排序.对于原子类型数据使用 ...

  9. bug修复复盘

    mybatis与数据库交互时,报了莫名其妙的错,日志中显示的Stack Trace中报错的代码行数与IDE中还一致,逐重启tomcat,异常消失. 故障复盘:没有重启tomcat,使用copy命令直接 ...

  10. uva 317 - Hexagon(规律推导)

    题目连接:317 - Hexagon 题目大意:在一个19个六边形组成的图形上玩一个游戏,给出9个数字, 分成3组, 分别可以填在左上角, 上, 有上角,因为对于小六边形来说, 对边的数是相同的, 然 ...

随机推荐

  1. Verilog 变量声明与数据类型一

    Verilog 变量声明与数据类型一 Verilog语法中最基本的数据类型有 线网(wire),寄存器(reg)和整数(integer)三种类型,这三种数据类型是可综合的数据类型,在Verilog 程 ...

  2. window监听节点改变的接口

    监听页面某个元素的属性变化 window.MutationObserver(callback) Mutation Observer API 用来监视 DOM 变动.比如节点的增减.属性的变动.文本内容 ...

  3. Jenkins系列(1)-离线安装插件

    插件地址:http://updates.jenkins-ci.org/download/plugins/

  4. 复杂数据类型(signal)的解读-C语言基础

    这一篇文章要探讨的是C语言中复杂数据类型的解读.涉及到signal()函数数据类型的解读(并不解释signal()的作用)以及对于数据类型的理解,属于C语言基础篇. 在开始解读signal()这种复杂 ...

  5. 我做的mysql 一些题 里面大部分都是mysql的方法

    基础题:-- 1. 查询Student表中的所有记录的Sname.Ssex和Class列.1 select sname,ssex,class from student;-- 2. 查询教师所有的单位即 ...

  6. Angular架构学习

    定义 Angular 是一个用 HTML 和 JavaScript 或者一个可以编译成 JavaScript 的语言(例如 Dart 或者 TypeScript ),来构建客户端应用的框架. 写 An ...

  7. ASP.NET的MVC模式中分布页和布局页的使用

    大概描述一下,分布页是布局页的一部分,分布页就相当于小图标,布局页就相当于PPT模板,PPT模板可以加入一些小图标(分布页),你只需要改改内容就好,视图创建的时候要选择包含布局页的 首先,去Contr ...

  8. 通过yum命令只下载rpm包不安装

    方法一:yumdownloader# 如果只想通过 yum 下载软件的软件包,但是不需要进行安装的话,可以使用 yumdownloader 命令: yumdownloader 命令在软件包 yum-u ...

  9. WIn环境基于vs编辑器,Qt应用申请管理员权限的解决方法(转载)

    原文章地址:https://blog.csdn.net/weixin_38416696/article/details/103879377 基本按照那个文章的操作.基本可以了. 唯一问题就是那个vs的 ...

  10. MySQLdb安装

    yum seach MySQL-Python sudo yum install MySQL-python.x86_64 import MySQLdb