T1: 温度转换

思路:模拟

public double[] convertTemperature(double celsius) {
return new double[]{celsius + 273.15, celsius * 1.80 + 32.00};
}

T2: 最小公倍数为 K 的子数组数目

思路:暴力枚举

  1. 关键在于如何高效求得两个数字的最小公倍数
  2. 最小公倍数 = a × b ÷ 最大公约数
  3. 使用辗转相除法求最大公约数
// 辗转相除法求最大公约数
public int gcd(int a, int b) {
if (a == 0) {
return b;
} return gcd(b % a, a);
} public int lcm(int a, int b) {
return a * b / (gcd(a, b));
} public int subarrayLCM(int[] nums, int k) {
int res = 0; // 暴力枚举所有子数组
for (int i = 0; i < nums.length; i++) {
if (nums[i] > k) {
continue;
} int temp = 1;
for (int j = i; j < nums.length; j++) {
temp = lcm(temp, nums[j]); // 剪枝条件
if (k % temp != 0) {
break;
} if (temp == k) {
res += 1;
}
}
} return res;
}

T3: 逐层排序二叉树所需的最少操作数目

本题解答参考学习 灵茶山艾府 大佬的题解。

思路:宽度优先搜索 + 置换环

本题抽象出来就是使得每一层数组元素有序的最小交换次数,该问题的做法是置换环。

如何寻找置换环:将这个数字当成下标去访问数组中的元素,不断循环直到回到这个数本身。对于每个置换环,需要的交换次数是 size - 1

public int minimumOperations(TreeNode root) {
//BFS
int res = 0;
Queue<TreeNode> queue = new ArrayDeque<>();
queue.offer(root); while (!queue.isEmpty()) {
int size = queue.size(); int[] arr = new int[size];
for (int i = 0; i < size; i++) {
TreeNode node = queue.poll();
arr[i] = node.val; if (node.left != null) {
queue.add(node.left);
} if (node.right != null) {
queue.add(node.right);
}
} res += exchangeTimes(arr);
} return res;
} public int exchangeTimes(int[] arr) {
int count = 0; // key: arr 元素值
// value: 对应元素应该放置的下标
Map<Integer, Integer> map = new HashMap<>();
int[] copy = Arrays.copyOf(arr, arr.length);
Arrays.sort(copy); for (int i = 0; i < copy.length; i++) {
map.put(copy[i], i);
} // 标记数组,表示下标为 i 的元素是否已被访问过
boolean[] flags = new boolean[arr.length]; for (int i = 0; i < arr.length; i++) {
if (!flags[i]) {
int j = i;
while (!flags[j]) {
flags[j] = true;
j = map.get(arr[j]);
} count += 1;
}
} return arr.length - count;
}

T4: 不重叠回文子字符串的最大数目

思路:中心拓展 + 动态规划

  • 中心拓展方法枚举回文子串的中心位置

  • 若子串 s[left, right] 是回文串,则 \(dp[right + 1] = Max(dp[right + 1], dp[left] + 1)\)

中心拓展枚举回文中心方法介绍

长度为 n 的字符串会生成 2n - 1 组回文中心 \([left_i, right_i]\),其中 \(left_i = i / 2, right_i = i / 2 + i \% 2\)

所以,在 0 ~ 2n-2 范围内遍历,即可得到所有可能的回文中心

public int maxPalindromes(String s, int k) {
char[] arr = s.toCharArray();
int n = arr.length; int[] dp = new int[n + 1]; // 中心拓展枚举回文子串
for (int i = 0; i < 2 * n - 1; i++) {
int left = i / 2;
int right = i / 2 + i % 2; dp[left + 1] = Math.max(dp[left + 1], dp[left]);
while (left >= 0 && right < n && arr[left] == arr[right]) {
if (right - left + 1 >= k) {
dp[right + 1] = Math.max(dp[right + 1], dp[left] + 1);
} left -= 1;
right += 1;
}
} return dp[n];

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

  1. leecode系列--Two Sum

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

  2. SGU 319. Kalevich Strikes Back (线段树)

    319. Kalevich Strikes Back Time limit per test: 0.5 second(s)Memory limit: 65536 kilobytes input: st ...

  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. Swing开发界面时的一个bug复盘

    问题:QA突然发个截图说一个Dialog上展示的东西变形了 分析:不理解,什么也没做,怎么会变形,刚刚我用的时候还正常.看看代码,的确什么也没更改:在本地测一下,也没有问题:baidu,bing,st ...

随机推荐

  1. P2212 Watering the Fields S

    题目描述 给定n个点,第i个点的坐标为(xi,yi)(xi​,yi​),如果想连通第i个点与第j个点,需要耗费的代价为两点的距离.第i个点与第j个点之间的距离使用欧几里得距离进行计算,即:(xi-xj ...

  2. django_模型层及ORM介绍

    一.模型层介绍 1.作用:负责跟数据库之间进行通信. 2.django通过驱动mysqlclient与mysql数据库进行通信,所以需要先安装.版本需要是1.3.13以上. 如果直接安装报错,可以直接 ...

  3. Window10设置技巧

    1.关闭应用程序上的最近打开文件,效果图 2.固定到"开始"屏幕,效果图 3.任务栏图标太大了

  4. Java代码结构

    Java代码结构 顺序结构 Java的基本结构为顺序结构,除非特别指明,否则从上到下一句一句执行 选择结构 if单选择结构 if(condition){ doSomething(); } if双选择结 ...

  5. Q:windows系统如何开机启动批处理脚本

    方法1 1.win+r输入gpedit.msc进入本地策略管理器 2.点击windows设置下的脚本(启动/关机),然后双击启动. 3.点击添加,然后点击浏览,选择批处理文件然后点击确定. 方法2 也 ...

  6. 磊磊零基础打卡算法:day18 c++模拟哈希表来模拟散列表

    5.21 哈希表 Hash表又称为散列表,一般由Hash函数(散列函数)与链表结构共同实现,与离散化思想类似. 一般要求:防止冲突,便于查询 模拟hash表: 拉链法:两个核心操作insert(),f ...

  7. PyQt5高级窗口组件

    https://blog.csdn.net/A642960662/article/details/123093350?utm_medium=distribute.pc_aggpage_search_r ...

  8. 廖雪峰python教程

    来源于廖雪峰博客园python教程 8-25 编程语言分类 机器语言 计算机内部只能接受二进制代码,用二进制代码0和1描述的指令称为机器指令,全部机器指令的集合构成计算机的机器语言,用机器语言编程的程 ...

  9. What Are You Weighting For?

    A basic strength routine can change your life Strength training isn't just about getting six-pack ab ...

  10. Springboot jar 打包脚本和启动脚本

    说明: SpringBoot极大的提高了工作效率,集成了各大厂优秀的组件,好处就不多说了,使用配置也非常方便,本文主要讲解如何使用更方便的方式打包发布,利用SpringBoot的新特性内置tomcat ...