【LeetCode每日一题合集】2023.8.14-2023.8.20(⭐切披萨3n块披萨)

news2024/11/25 22:43:00

文章目录

  • 617. 合并二叉树
  • 833. 字符串中的查找与替换(模拟)
  • 2682. 找出转圈游戏输家(模拟)
  • 1444. 切披萨的方案数(⭐⭐⭐⭐⭐)
    • 解法——从递归到递推到优化(二维前缀和+记忆化搜索)
  • 1388. 3n 块披萨(⭐⭐⭐⭐⭐脑筋急转弯:转换问题)
    • 解法——将问题转化为:选择n个披萨,且任意两个数不能相邻,求这n个数的最大值(环形打家劫舍 + 最多买卖k次的股票)
  • 2235. 两整数相加(真·梦开始的地方)
  • 2236. 判断根结点是否等于子结点之和(真·梦开始的地方2)

617. 合并二叉树

https://leetcode.cn/problems/merge-two-binary-trees/

在这里插入图片描述

提示:
两棵树中的节点数目在范围 [0, 2000] 内
-10^4 <= Node.val <= 10^4

class Solution {
    public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {
        if (root1 == null) return root2;
        else if (root2 == null) return root1;

        root1.val += root2.val;
        root1.left = mergeTrees(root1.left, root2.left);
        root1.right = mergeTrees(root1.right, root2.right);
        return root1;
    }
}

833. 字符串中的查找与替换(模拟)

https://leetcode.cn/problems/find-and-replace-in-string/
在这里插入图片描述

只看题面比较难以理解题目意思,得看一个示例:
在这里插入图片描述

提示:
1 <= s.length <= 1000
k == indices.length == sources.length == targets.length
1 <= k <= 100
0 <= indexes[i] < s.length
1 <= sources[i].length, targets[i].length <= 50
s 仅由小写英文字母组成
sources[i] 和 targets[i] 仅由小写英文字母组成

class Solution {
    public String findReplaceString(String s, int[] indices, String[] sources, String[] targets) {
        int n = s.length();
        String[] ans = new String[n];   // 存储每个位置被换成了什么
        for (int i = 0; i < indices.length; ++i) {
            // 检查是否需要替换
            if (indices[i] + sources[i].length() <= n && sources[i].equals(s.substring(indices[i], indices[i] + sources[i].length()))) {
                ans[indices[i]] = targets[i];
                for (int j = indices[i] + 1; j < indices[i] + sources[i].length(); ++j) ans[j] = "";
            }
        }
        // 没有被替换的位置还是保持原样
        for (int i = 0; i < n; ++i) {
            if (ans[i] == null) ans[i] = s.substring(i, i + 1);
        }
        return String.join("", ans);
    }
}

2682. 找出转圈游戏输家(模拟)

https://leetcode.cn/problems/find-the-losers-of-the-circular-game/

在这里插入图片描述

提示:
1 <= k <= n <= 50

class Solution {
    public int[] circularGameLosers(int n, int k) {
        int[] cnt = new int[n];
        int l = n;
        for (int i = 0, s = k; cnt[i] == 0; i = (i + s) % n, s += k) {
            l--;
            cnt[i]++;
        }
        int[] ans = new int[l];
        for (int i = 0, j = 0; i < n; ++i) {
            if (cnt[i] == 0) ans[j++] = i + 1;
        }
        return ans;
    }
}

为方便取模运算,循环中的下标可以从 0 开始,在返回时再加一。

1444. 切披萨的方案数(⭐⭐⭐⭐⭐)

https://leetcode.cn/problems/number-of-ways-of-cutting-a-pizza/
在这里插入图片描述
提示:
1 <= rows, cols <= 50
rows == pizza.length
cols == pizza[i].length
1 <= k <= 10
pizza 只包含字符 'A' 和 '.' 。

解法——从递归到递推到优化(二维前缀和+记忆化搜索)

https://leetcode.cn/problems/number-of-ways-of-cutting-a-pizza/solutions/2392051/ji-bai-100cong-di-gui-dao-di-tui-dao-you-dxz5/

定义 dfs(c, i, j) 表示把左上角在 (i, j),右下角在 (m - 1, n - 1) 的子矩阵切 c 刀,每块都至少包含一个苹果的方案数。

class Solution {
    static final int MOD = (int)1e9 + 7;
    int[][][] memo;

    public int ways(String[] pizza, int k) {
        MatrixSum ms = new MatrixSum(pizza);
        int m = pizza.length, n = pizza[0].length();
        memo = new int[k][m][n];
        for (int i = 0; i < k; ++i) {
            for (int j = 0; j < m; ++j) {
                Arrays.fill(memo[i][j], -1);
            }
        }
        return dfs(k - 1, 0, 0, ms, m, n);
    }

    public int dfs(int c, int i, int j, MatrixSum ms, int m, int n) {
        if (c == 0) {       // 不能再切了,检查是否还剩下苹果
            return ms.query(i, j, m, n) > 0? 1: 0;
        } 
        if (memo[c][i][j] != -1) return memo[c][i][j];
        int res = 0;
        // 枚举竖直切
        for (int j2 = j + 1; j2 < n; ++j2) {
            if (ms.query(i, j, m, j2) > 0) {
                res = (res + dfs(c - 1, i, j2, ms, m, n)) % MOD;
            }
        }
        // 枚举水平切
        for (int i2 = i + 1; i2 < m; ++i2) {
            if (ms.query(i, j, i2, n) > 0) {
                res = (res + dfs(c - 1, i2, j, ms, m, n)) % MOD;
            }
        }
        return memo[c][i][j] = res;
    }
}

// 二维前缀和模板('A'的ASCII码最低位为1,'.'的ASCII码的最低位为0)
class MatrixSum {
    private final int[][] sum;

    public MatrixSum (String[] matrix) {
        int m = matrix.length, n = matrix[0].length();
        sum = new int[m + 1][n + 1];
        for (int i = 0; i < m; ++i) {
            for (int j = 0; j < n; ++j) {
                sum[i + 1][j + 1] = (matrix[i].charAt(j) & 1) + sum[i + 1][j] + sum[i][j + 1] - sum[i][j];
            }
        }
    }

    // 返回左上角为(r1,c1),右下角为(r2-1,c2-1)的子矩阵的元素和
    public int query(int r1, int c1, int r2, int c2) {
        return sum[r2][c2] - sum[r2][c1] - sum[r1][c2] + sum[r1][c1];
    }
}

1388. 3n 块披萨(⭐⭐⭐⭐⭐脑筋急转弯:转换问题)

https://leetcode.cn/problems/pizza-with-3n-slices/
在这里插入图片描述

提示:
1 <= slices.length <= 500
slices.length % 3 == 0
1 <= slices[i] <= 1000

解法——将问题转化为:选择n个披萨,且任意两个数不能相邻,求这n个数的最大值(环形打家劫舍 + 最多买卖k次的股票)

有点像 环形打家劫舍 + 最多买卖k次的股票 的结合。

dp[i][j] 表示考虑 0 ~ i 下标的 slices,购买 j 个最大价值。

class Solution {
    public int maxSizeSlices(int[] slices) {
        int n = slices.length;
        int a = op(slices, 0, n - 2), b = op(slices, 1, n - 1);
        return Math.max(a, b);
    }

    public int op(int[] slices, int start, int end) {
        int n = end - start + 1, m = (n + 1) / 3;
        int[][] dp = new int[n][m + 1];
        for (int i = 0; i < n; ++i) Arrays.fill(dp[i], Integer.MIN_VALUE);
        dp[0][0] = 0;
        dp[0][1] = slices[start];
        dp[1][0] = 0;
        dp[1][1] = Math.max(slices[start], slices[start + 1]);
        for (int i = 2; i < n; ++i) {
            dp[i][0] = 0;
            for (int j = 1; j <= m; ++j) {
                dp[i][j] = Math.max(dp[i - 1][j], dp[i - 2][j - 1] + slices[i + start]);
            }
        }
        return dp[n - 1][m];
    }
}

2235. 两整数相加(真·梦开始的地方)

https://leetcode.cn/problems/add-two-integers/

在这里插入图片描述
提示:
-100 <= num1, num2 <= 100

class Solution {
    public int sum(int num1, int num2) {
        return num1 + num2;
    }
}

2236. 判断根结点是否等于子结点之和(真·梦开始的地方2)

https://leetcode.cn/problems/root-equals-sum-of-children/description/

在这里插入图片描述

提示:
树只包含根结点、左子结点和右子结点
-100 <= Node.val <= 100

class Solution {
    public boolean checkTree(TreeNode root) {
        return root.left.val + root.right.val == root.val;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/969819.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【LeetCode每日一题合集】2023.8.7-2023.8.13(动态规划分治)

文章目录 344. 反转字符串1749. 任意子数组和的绝对值的最大值&#xff08;最大子数组和&#xff09;1281. 整数的各位积和之差1289. 下降路径最小和 II解法1——动态规划 O ( n 3 ) O(n^3) O(n3)解法2——转移过程优化 O ( n 2 ) O(n^2) O(n2) ⭐ 1572. 矩阵对角线元素的和解法…

13.Redis 事务

Redis 事务 redis 事务事务操作multi 开启事务exec 执行事务discard 放弃当前事务watchunwatch redis 事务 Redis 的事务和 MySQL 的事务概念上是类似的。 都是把⼀系列操作绑定成⼀组。 让这⼀组能够批量执⾏。 Redis 的事务和 MySQL 事务的区别: 弱化的原⼦性: 这里指的是 …

Pinely Round 2 (Div. 1 + Div. 2) G. Swaps(组合计数)

题目 给定一个长度为n(n<1e6)的序列&#xff0c;第i个数ai(1<ai<n)&#xff0c; 操作&#xff1a;你可以将当前i位置的数和a[i]位置的数交换 交换可以操作任意次&#xff0c;求所有本质不同的数组的数量&#xff0c;答案对1e97取模 思路来源 力扣群 潼神 心得 感…

huggingface下载模型文件(基础入门版)

huggingface是一个网站&#xff0c;类似于github&#xff0c;上面拥有众多开源的模型、数据集等资料&#xff0c;人工智能爱好者可以很方便的上面获取需要的数据&#xff0c;也可以上传训练好的模型&#xff0c;制作的数据集等。本文只介绍下载模型的方法&#xff0c;适合新手入…

SpringBoot连接MySQL数据库,使用Mybatis框架(入门)

1. 说明 SpringBoot项目&#xff0c;连接MySQL数据库&#xff0c;使用Mybatis框架。 本篇文章作为 SpringBoot 使用 Mybatis 的入门。 2. 依赖 2.1. MySQL驱动依赖 MySQL驱动&#xff0c;使用SpringBoot版本对应的默认版本&#xff0c;不需要手动指定版本。 比如&#xf…

【狂神】Spring5 (三) 之Aop的实现方式

今天没有偷懒&#xff0c;只是忘了Mybatis&#xff0c;所以去补课了~ ┏━━━━━━━━━━━━━━━┓ NICE PIGGY PIG.. ┗━━━━━━━△━━━━━━━┛ ヽ(&#xff65;ω&#xff65;)&#xff89; | / UU 1.Aop实现方式一 1.1、什…

UG\NX CAM二次开发 查询工序所在的方法组TAG UF_OPER_ask_method_group

文章作者:代工 来源网站:NX CAM二次开发专栏 简介: UG\NX CAM二次开发 查询工序所在的方法组TAG UF_OPER_ask_method_group 效果: 代码: void MyClass::do_it() { int count=0;tag_t * objects;UF_UI_ONT_ask_selected_nodes(&count, &objects);for (i…

Multimedia-播放器-架构2

目录 引言 问题1&#xff1a; 数据缓冲区 多线程模型 缓冲区的特点&#xff1a; 点播和直播场景中的缓冲区&#xff1a; 问题2&#xff1a; 同步方式 同步实现过程 引言 上一篇梳理了播放器的基本工作与处理流程&#xff0c;本片内容主要梳理一下其中会遇到的问题&am…

桂理理工大题

#include <stdio.h> #include <stdlib.h>int getMax(int n); int getMin(int n); int range(int n); static int count1; //作为全局变量控制每次的序列号int main(){int num;int i,j;do{printf("输入黑洞数&#xff1a;\n");scanf("%d",&…

Jdk8 动态编译 Java 源码为 Class 文件(三)

Jdk8 动态编译 Java 源码为 Class 文件 一.JDK版本二.工程介绍1.依赖2.启动类3.配置类&#xff08;用于测试依赖注入&#xff09;4.工具类1.Java 源码文件读取类2.SpringBoot 容器实例管理类 5.测试类1.抽象类2.接口类3.默认抽象实现4.默认接口实现 6.接口类1.测试接口2.类重载…

数学建模:模糊综合评价分析

&#x1f506; 文章首发于我的个人博客&#xff1a;欢迎大佬们来逛逛 数学建模&#xff1a;模糊综合评价分析 文章目录 数学建模&#xff1a;模糊综合评价分析综合评价分析常用评价方法一级模糊综合评价综合代码 多级模糊综合评价总结 综合评价分析 构成综合评价类问题的五个…

Emmet 使用笔记小结

Emmet 使用笔记小结 最近在跟视频走 CSS 的教程&#xff0c;然后要写很多的 HTML 结构&#xff0c;就想着总结一下 Emmet 的语法。 Emmet 是一个工具可以用来加速 HTML 和 CSS 的开发过程&#xff0c;不过 emmet 只支持 HTML & XML 文件结构&#xff0c;所以我个人觉得对…

【JavaSE】面试01

文章目录 1. JDK、JRE、JVM之间的关系2. 补充3. 面试题&#xff1a;重载和重写的区别&#xff1f;4. super和this5. &#xff08;重点&#xff01;&#xff01;&#xff09;若父类和子类均有静态代码块、实例代码块以及无参构造方法&#xff0c;则继承关系上的执行顺序&#xf…

如何解决分库分表主键问题?

分析&回答 从问题角度出发&#xff1a;我们需要一个全局唯一的 id 来支持&#xff0c;排序问题等。这都是你实际生产环境中必须考虑的问题。可以先看下我们之前的文章分布式系统唯一ID如何生成&#xff1f; 雪花算法和雪花算法的变种是大家常用的 喵呜面试助手&#xff1…

Python字节码文件

迷途小书童的 Note 读完需要 5分钟 速读仅需 2 分钟 大家好&#xff0c;我是迷途小书童&#xff01; 今天给大家介绍一个神奇的文件 -- pyc 文件&#xff0c;它能加速 Python 程序的执行速度&#xff0c;同时也能起到保护源码的作用。 1 什么是 pyc 文件? pyc 文件是经过编译的…

PYTHON-“人生重开模拟器“

&#x1f680;write in front&#x1f680; &#x1f50e;大家好&#xff0c;我是Aileen★。希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流&#x1f50e; &#x1f194;本文由 Aileen_0v0★ 原创 CSDN首发&#x1f412; 如需转载还…

SAP-PP:基础概念笔记-5(物料主数据的MRP1~4视图)

文章目录 前言一、MRP1视图Base Unit of Measure&#xff08;UoM&#xff09;MRP 组采购组ABC 指示器Plant-Specific Material Status 特定的工厂物料状态MRP 类型 MRP TypeMRP 类型 MRP TypeMaster Production Scheduling(MPS) 主生产计划基于消耗的计划(CBP)再订货点Reorder-…

【业务功能篇91】微服务-springcloud-多线程-线程池执行顺序

一、线程的实现方式 1. 线程的实现方式 1.1 继承Thread class ThreadDemo01 extends Thread{Overridepublic void run() {System.out.println("当前线程:" Thread.currentThread().getName());} }1.2 实现Runnable接口 class ThreadDemo02 implements Runnable{…

介绍几个搜索引擎

Google&#xff1a;全球最大的搜索引擎&#xff0c;提供全面的搜索服务&#xff0c;包括网页、图片、视频、新闻、地图等。 Baidu&#xff1a;中国最大的搜索引擎&#xff0c;提供类似于Google的全面搜索服务&#xff0c;同时也有网盘、知道等功能。 Bing&#xff1a;微软公司…

Linux持续学习者的实用命令:sed

引言 作为一名Linux持续学习者&#xff0c;我们经常需要对文本内容进行处理或修改&#xff0c;这时候sed命令就能派上用场了。sed是一个强大的流式文本编辑器&#xff0c;它可以在读取文本时进行修改并输出&#xff0c;支持各种复杂的字符串替换、内容删除、行插入等操作。在本…