Leetcode 第 379 场周赛题解

Leetcode 第 379 场周赛题解

  • Leetcode 第 379 场周赛题解
    • 题目1:10035. 对角线最长的矩形的面积
      • 思路
      • 代码
      • 复杂度分析
    • 题目2:10036. 捕获黑皇后需要的最少移动次数
      • 思路
      • 代码
      • 复杂度分析
    • 题目3:10037. 移除后集合的最多元素数
      • 思路
      • 代码
      • 复杂度分析
    • 题目4:10038. 执行操作后的最大分割数量
      • 思路
      • 代码
      • 复杂度分析

Leetcode 第 379 场周赛题解

题目1:10035. 对角线最长的矩形的面积

思路

模拟。

代码

/** @lc app=leetcode.cn id=10035 lang=cpp** [10035] 对角线最长的矩形的面积*/// @lc code=start
class Solution
{
public:int areaOfMaxDiagonal(vector<vector<int>> &dimensions){// 特判if (dimensions.empty())return 0;double maxDiagonal = 0.0;int maxArea = 0;for (vector<int> &dimension : dimensions){int length = dimension[0], width = dimension[1];if (sqrt(length * length + width * width) > maxDiagonal){maxDiagonal = sqrt(length * length + width * width);maxArea = length * width;}else if (sqrt(length * length + width * width) == maxDiagonal)maxArea = max(maxArea, length * width);}return maxArea;}
};
// @lc code=end

复杂度分析

时间复杂度:O(n),其中 n 是数组 dimensions 的长度。

空间复杂度:O(1)。

题目2:10036. 捕获黑皇后需要的最少移动次数

思路

分类讨论:

  • 如果车能直接攻击到皇后,答案是 1。
  • 如果象能直接攻击到皇后,答案是 1。
  • 如果车被象挡住,那么移走象,车就可以攻击到皇后,答案是 2。
  • 如果象被车挡住,那么移走车,象就可以攻击到皇后,答案是 2。
  • 如果车不能直接攻击到皇后,那么车可以水平移动或者垂直移动,其中一种方式必定不会被象挡住,可以攻击到皇后,答案是 2。

对于车,如果和皇后在同一水平线或者同一竖直线,且中间没有象,那么就可以直接攻击到皇后。

对于象,如果和皇后在同一斜线,且中间没有车,那么就可以直接攻击到皇后。

代码

/** @lc app=leetcode.cn id=10036 lang=cpp** [10036] 捕获黑皇后需要的最少移动次数*/// @lc code=start
class Solution
{
public:int minMovesToCaptureTheQueen(int a, int b, int c, int d, int e, int f){// 车和皇后在一条横线上,且它们之间没有象if (a == e && !(a == c && d > min(b, f) && d < max(b, f)))return 1;// 车和皇后在一条竖线上,且它们之间没有象if (b == f && !(b == d && c > min(a, e) && c < max(a, e)))return 1;// 象和皇后在一条斜线上,且它们之间没有车if ((c + d == e + f && !(a + b == e + f && a > min(c, e) && a < max(c, e))) ||(c - d == e - f && !(a - b == e - f && a > min(c, e) && a < max(c, e))))return 1;return 2;}
};
// @lc code=end

复杂度分析

时间复杂度:O(1)。

空间复杂度:O(1)。

题目3:10037. 移除后集合的最多元素数

思路

贪心。

可以将数组去重后分为三个部分:nums1 独有的,nums2 独有的,nums1 与 nums2 共有的。

求集合 S 时:

  1. 先选择两个数组独有的。
  2. 对于共有的,两个数组尽量选不一样的。

代码

/** @lc app=leetcode.cn id=10037 lang=cpp** [10037] 移除后集合的最多元素数*/// @lc code=start
class Solution
{
public:int maximumSetSize(vector<int> &nums1, vector<int> &nums2){int n = nums1.size();unordered_set<int> set1, set2;for (int &x : nums1)set1.insert(x);for (int &x : nums2)set2.insert(x);int common = 0; // 两个数组共有的元素个数for (int x : set1)if (set2.count(x))common++;// count1 和 count2 分别为数组 nums1 和 nums2 独有元素的个数int count1 = set1.size() - common, count2 = set2.size() - common;// 贪心策略:先选二者独有的,没得选才选二者共有的int s1 = min(count1, n / 2), s2 = min(count2, n / 2);return s1 + s2 + min(n - s1 - s2, common);}
};
// @lc code=end

复杂度分析

时间复杂度:O(n),其中 n 是数组 nums1/nums2 的长度。

空间复杂度:O(n),其中 n 是数组 nums1/nums2 的长度。

题目4:10038. 执行操作后的最大分割数量

思路

题解:两种方法:记忆化搜索/O(n)前后缀分解(Python/Java/C++/Go)

代码

/** @lc app=leetcode.cn id=10038 lang=cpp** [10038] 执行操作后的最大分割数量*/// @lc code=start// 记忆化搜索+记录字符集合class Solution
{
public:int maxPartitionsAfterOperations(string s, int k){unordered_map<long long, int> memo;function<int(int, int, bool)> dfs = [&](int i, int mask, bool changed) -> int{if (i == s.length()){return 1;}long long args_mask = (long long)i << 32 | mask << 1 | changed;auto it = memo.find(args_mask);if (it != memo.end()){ // 之前计算过return it->second;}int res;// 不改 s[i]int bit = 1 << (s[i] - 'a');int new_mask = mask | bit;if (__builtin_popcount(new_mask) > k){// 分割出一个子串,这个子串的最后一个字母在 i-1// s[i] 作为下一段的第一个字母,也就是 bit 作为下一段的 mask 的初始值res = dfs(i + 1, bit, changed) + 1;}else{ // 不分割res = dfs(i + 1, new_mask, changed);}if (!changed){// 枚举把 s[i] 改成 a,b,c,...,zfor (int j = 0; j < 26; j++){new_mask = mask | (1 << j);if (__builtin_popcount(new_mask) > k){// 分割出一个子串,这个子串的最后一个字母在 i-1// j 作为下一段的第一个字母,也就是 1<<j 作为下一段的 mask 的初始值res = max(res, dfs(i + 1, 1 << j, true) + 1);}else{ // 不分割res = max(res, dfs(i + 1, new_mask, true));}}}return memo[args_mask] = res; // 记忆化};return dfs(0, 0, false);}
};
// @lc code=end

复杂度分析

在这里插入图片描述

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

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

相关文章

SpringBoot+SSM项目实战 苍穹外卖(11) Apache ECharts

继续上一节的内容&#xff0c;本节学习Apache ECharts&#xff0c;实现营业额统计、用户统计、订单统计和销量排名Top10功能。 数据统计效果图&#xff1a; 目录 Apache ECharts入门案例 营业额统计用户统计订单统计销量排名Top10 Apache ECharts Apache ECharts 是一款基于 …

Debezium发布历史67

原文地址&#xff1a; https://debezium.io/blog/2019/08/20/debezium-0-10-0-beta4-released/ 欢迎关注留言&#xff0c;我是收集整理小能手&#xff0c;工具翻译&#xff0c;仅供参考&#xff0c;笔芯笔芯. Debezium 0.10.0.Beta4 发布 八月 20, 2019 作者&#xff1a; Gun…

解锁 JavaScript 数组的强大功能:常用方法和属性详解(上)

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…

20240114总结:无聊周末or有聊周末

有时候&#xff0c;连着几个周末感觉好忙&#xff0c;比如要去体检、验光、复光、爬山、打球、参加婚礼、跨年、年终总结、、练习讲话、乙肝疫苗、正骨、按摩、西丽湖吃饭、每天三国一两个钟、看下电影啥的&#xff0c;很快&#xff0c;很碎片。 但是这个周末完全没任务&#…

Java中HashSet如何检查重复

HashSet是基于哈希表实现的无序的、不重复的集合类。它在添加元素时会自动检查是否存在重复元素&#xff0c;通过hashCode()和equals()方法来确定元素的相等性。 HashSet添加元素步骤&#xff0c;先通过hashCode找出位置&#xff0c;再通过equals()比较是否相等&#xff1a; …

毕业设计:基于python微博舆情分析系统+可视化+Django框架 K-means聚类算法(源码)✅

毕业设计&#xff1a;2023-2024年计算机专业毕业设计选题汇总&#xff08;建议收藏&#xff09; 毕业设计&#xff1a;2023-2024年最新最全计算机专业毕设选题推荐汇总 &#x1f345;感兴趣的可以先收藏起来&#xff0c;点赞、关注不迷路&#xff0c;大家在毕设选题&#xff…

C++ 完成Client分页显示log

分页显示t_log 1、获取用户的输入 1.1、写一个Input成员函数&#xff0c;处理输入进来的语句 std::string XClient::Input() {//清空缓冲//cin.ignore(4096, \n);string input "";for (;;){char a getchar();if (a < 0 || a \n || a \r)break;cout <<…

数据化思维:数据聚集与管理,数据运用与分析

数据化思维 数据化思维&#xff0c;是指在面对复杂问题时&#xff0c;通过收集、处理和分析数据&#xff0c;以数据为依据进行决策和解决问题的思维方式。它强调用事实说话&#xff0c;注重量化指标&#xff0c;能够帮助我们在海量信息中抽丝剥茧&#xff0c;发现深层次规律和…

LlamaIndex中的CustomLLM(在线加载模型)

一.使用 Flask 将模型封装为 REST 接口 主要是将 complete()和 stream_complete()方法封装为 REST 接口&#xff0c;如下所示&#xff1a; from flask import Flask, request, jsonify from transformers import AutoTokenizer, AutoModelForCausalLM app Flask(__name__)cla…

Linux comm命令教程:对比和分析文件内容(附案例详解和注意事项)

Linux comm命令介绍 comm&#xff0c;又称为_compare common lines_命令&#xff0c;是一个简易的Linux文件比较工具&#xff0c;主要用于标识出两个已排序文件中的共同部分。该命令逐行比较两个文件&#xff0c;并以三列形式显示结果。 Linux comm命令适用的Linux版本 通常…

Kubernetes 面试宝典

创建 Pod的主要流程? 客户端提交 Pod 的配置信息(可以是 yaml 文件定义的信息)到 kube-apiserver. Apiserver 收到指令后,通知 controllr-manager 创建一个资源对象 controller-manager 通过 apiserver 将 pod 的配置信息存储到 ETCD 数据中薪心中 kube-scheduler 检查到 p…

GPT编程:运行你的第一个聊天程序

环境搭建 很多机器学习框架和类库都是使用Python编写的&#xff0c;OpenAI提供的很多例子也是Python编写的&#xff0c;所以为了方便学习&#xff0c;我们这个教程也使用Python。 Python环境搭建 Python环境搭建有很多种方法&#xff0c;我们这里需要使用 Python 3.10 的环境…

一二三应用开发平台文件处理设计与实现系列之5——MinIO技术预研

背景 上篇介绍了文件读写框架设计与实现&#xff0c;同时顺便说明了本地磁盘存储模式的实现模式。 今天来说下基于文件读写框架&#xff0c;如何集成对象存储组件minio&#xff0c;集成之前&#xff0c;需要对minio进行必要的了解&#xff0c;本篇是minio的技术预研。 minio简…

两个Mesh路由、一个5口交换机,打造智能家居无缝网络覆盖

在现代家庭中&#xff0c;无线网络已经成为了必需品&#xff0c;每个人都希望享受到无缝连接的畅快体验。然而&#xff0c;由于信号覆盖范围的限制和信号干扰等问题&#xff0c;很多家庭在组网方面遇到了一些困难。 对于有需求的家庭而言&#xff0c;两个Mesh路由器是一种非常…

Linux|centos7操作系统|VMware虚拟机安装水星免驱USB网卡8188gu记录

引言&#xff1a; 最近对于嵌入式系统比较感兴趣&#xff0c;因此&#xff0c;计划先使用VMware workstation虚拟机试一试Linux系统下的网卡驱动安装 这不试不知道&#xff0c;一试吓一跳&#xff0c;发现Linux下的驱动安装还是比较麻烦的&#xff0c;下面将就本次的Linux系统…

机器学习 | 卷积神经网络

机器学习 | 卷积神经网络 实验目的 采用任意一种课程中介绍过的或者其它卷积神经网络模型&#xff08;例如LeNet-5、AlexNet等&#xff09;用于解决某种媒体类型的模式识别问题。 实验内容 卷积神经网络可以基于现有框架如TensorFlow、Pytorch或者Mindspore等构建&#xff…

Linux 专栏目录

常用指令 curl 1. curl -i 和 -I&#xff08;i 大写&#xff09;的区别 2. curl 只显示需要的行信息 scp 1. scp 服务器之间传输文件

格密码基础:SIS问题的困难性

目录 一. SIS问题的困难性 二. SIS问题归约的性质 2.1 2004年 [MR04] 2.2 2008年 【GPV08】 2.3 2013年【MP13】 三. 归约证明 3.1 核心理解 3.2 归约步骤 3.3 性质理解 一. SIS问题的困难性 推荐先阅读&#xff1a; 格密码基础&#xff1a;SIS问题的定义与理解-CSD…

专业课140总分410+大连理工大学852信号与系统考研经验电子信息与通信

通过将近一年的复习&#xff0c;今年如愿以专业140分&#xff0c;总分410被大连理工录取&#xff0c;回望这一年复习还是有很多做的不足&#xff0c;整理了一下自己复习的经验&#xff0c;希望可以对后面报考大连理工的同学有所帮助。●政治&#xff1a; 真心建议大家至少暑假…

深入理解 go reflect - 反射常见错误

go 的反射是很脆弱的&#xff0c;保证反射代码正确运行的前提是&#xff0c;在调用反射对象的方法之前&#xff0c; 先问一下自己正在调用的方法是不是适合于所有用于创建反射对象的原始类型。 go 反射的错误大多数都来自于调用了一个不适合当前类型的方法&#xff08;比如在一…