Leetcode 第 410 场周赛题解

Leetcode 第 410 场周赛题解

  • Leetcode 第 410 场周赛题解
    • 题目1:3248. 矩阵中的蛇
      • 思路
      • 代码
      • 复杂度分析
    • 题目2:3249. 统计好节点的数目
      • 思路
      • 代码
      • 复杂度分析
    • 题目3:3250. 单调数组对的数目 I
      • 思路
      • 代码
      • 复杂度分析
    • 题目4:3251. 单调数组对的数目 II
      • 思路
      • 代码
      • 复杂度分析

Leetcode 第 410 场周赛题解

题目1:3248. 矩阵中的蛇

思路

遍历字符串数组 commands,模拟🐍的移动过程。

如果最后🐍的位置为 (i, j),则编号为 (i * n) + j。

代码

/** @lc app=leetcode.cn id=3248 lang=cpp** [3248] 矩阵中的蛇*/// @lc code=start
class Solution
{
public:int finalPositionOfSnake(int n, vector<string> &commands){int i = 0, j = 0;for (string &cmd : commands){switch (cmd[0]){case 'U':i--;break;case 'R':j++;break;case 'D':i++;break;case 'L':j--;break;default:break;}}return (i * n) + j;}
};
// @lc code=end

复杂度分析

时间复杂度:O(n),其中 n 是字符串数组 commands 的长度。

空间复杂度:O(1)。

题目2:3249. 统计好节点的数目

思路

建树,然后从根节点 0 开始 DFS 这棵树。

DFS 返回子树大小。

对于节点 x,如果其是叶子节点,或者其所有儿子子树大小都一样,那么答案加一。

代码

/** @lc app=leetcode.cn id=3249 lang=cpp** [3249] 统计好节点的数目*/// @lc code=start
class Solution
{
public:int countGoodNodes(vector<vector<int>> &edges){int n = edges.size() + 1; // 节点数// 构建邻接表vector<vector<int>> adj(n);for (vector<int> &edge : edges){int u = edge[0], v = edge[1];adj[u].push_back(v);adj[v].push_back(u);}int ans = 0;// parent 为父节点function<int(int, int)> dfs = [&](int u, int parent) -> int{int cnt_sum = 1; // 节点总数,先计入自身int single_cnt = 0;bool valid = true;for (int v : adj[u]){// 规避邻接点中已访问过的父节点,不需要 visited 数组if (v == parent)continue;int cnt = dfs(v, u);cnt_sum += cnt;// 检测子树的节点数量是否相同if (single_cnt == 0)single_cnt = cnt;else if (single_cnt != cnt)valid = false;}ans += valid;return cnt_sum;};dfs(0, -1); // -1 即不存在父节点return ans;}
};
// @lc code=end

复杂度分析

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

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

题目3:3250. 单调数组对的数目 I

思路

题目输入一个数组nums。

假设有两个数组A和B,A递增,B递减,且 Ai + Bi = numsi

问有多少对(A,B)数组对。

解法:

在这里插入图片描述

代码

#
# @lc app=leetcode.cn id=3250 lang=python3
#
# [3250] 单调数组对的数目 I
## @lc code=start# 记忆化搜索class Solution:def countOfPairs(self, nums: List[int]) -> int:MOD = 10 ** 9 + 7n = len(nums)@cachedef dfs(i, a):if i == n - 1:return 1res = 0b = nums[i] - afor na in range(nums[i + 1] + 1):nb = nums[i + 1] - naif a <= na and b >= nb:res += dfs(i + 1, na)return res % MODres = 0for num in range(nums[0] + 1):res += dfs(0, num)res %= MODreturn res
# @lc code=end

复杂度分析

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

空间复杂度:O(n * m),其中 n 是数组 nums 的长度。

题目4:3251. 单调数组对的数目 II

思路

设 f[i][j] 表示下标 0 到 i 中的单调数组对的个数,且 arr1[i]=j。

在这里插入图片描述

代码

/** @lc app=leetcode.cn id=3251 lang=cpp** [3251] 单调数组对的数目 II*/// @lc code=start
class Solution
{
private:const int MOD = 1e9 + 7;public:int countOfPairs(vector<int> &nums){int n = nums.size();int m = *max_element(nums.begin(), nums.end());vector<vector<long long>> dp(n, vector<long long>(m + 1));vector<long long> preSum(m + 1);fill(dp[0].begin(), dp[0].begin() + nums[0] + 1, 1);for (int i = 1; i < n; i++){partial_sum(dp[i - 1].begin(), dp[i - 1].end(), preSum.begin()); // dp[i-1] 的前缀和for (int j = 0; j <= nums[i]; j++){int max_k = j + min(nums[i - 1] - nums[i], 0);dp[i][j] = max_k >= 0 ? preSum[max_k] % MOD : 0;}}return accumulate(dp[n - 1].begin(), dp[n - 1].begin() + nums[n - 1] + 1, 0LL) % MOD;}
};
// @lc code=end

复杂度分析

时间复杂度:O(n * m),其中 n 是数组 nums 的长度,m=max(nums)。

空间复杂度:O(n * m),其中 n 是数组 nums 的长度,m=max(nums)。

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

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

相关文章

nvm list available出现的 Could not retrieve https://nodejs.org/dist/index.json办法解决

好久没有用电脑的nvm list available 命令&#xff0c;今天晚上突然用发现趟趟趟~~ 报错 刚开始报错&#xff1a;是这样滴 Could not retrieve https://nodejs.org/dist/index.json.Get https://nodejs.org/dist/index.json: net/http: TLS handshake timeout方法尝试1&#…

COB超微小间距LED显示屏是什么,它的性价比怎么样,市场大有可为

COB&#xff08;Chip on Board&#xff09;技术最早发源于上世纪60年代&#xff0c;是将LED芯片直接封装在PCB电路板上&#xff0c;并用特种树脂做整体覆盖。COB实现“点” 光源到“面” 光源的转换。点间距有P0.3、P0.4、P0.5、P0.6、P0.7、P0.9、P1.25、P1.538、P1.5625、P1.…

【苍穹外卖】Day4 套餐接口

1 数据设计 /*** 套餐*/ Data Builder NoArgsConstructor AllArgsConstructor public class Setmeal implements Serializable {private static final long serialVersionUID 1L;private Long id;//分类idprivate Long categoryId;//套餐名称private String name;//套餐价格p…

Renesa Version Board开发RT-Thread 之Client(WIFI)和上位机的数据传输

目录 概述 1 系统框架 1.1 模块介绍 1.1 Version-Board 开发板 1.1.1 Vision-Board简介 1.1.2 Vision-Board的资源 1.2 框架介绍 2 上位机App 2.1 UI设计 2.2 代码实现 3 功能测试 3.1 网络连接 3.2 功能测试 概述 本文主要Renesa Version Board开发RT-Thread 之…

与MySQL邂逅

MySQL安装捏~ 其实每次新学一样东西&#xff0c;安装永远是一个小坎 但是小问题啦 安装MySQL要用root账户&#xff0c;安装后普通用户也可以用捏 要安装MySQL先来看第一步&#xff01; 改bug&#xff01; Centos 卸载不要的环境 先康康有木有捏&#xff1a; mariadb就是…

ElasticSearch-聚合操作

聚合的分类 aggsMetric Aggregation min, max, avg, sumstats, cardinality Bucket Aggregation terms ordertext -> fielddatarangehistogramtop_hits Pipeline Aggregation min_bucketstats_bucketpercentiles_bucketcumulative_sum 聚合的作用范围 Filter, Post Filter,…

AI智能电销机器人的优势是什么,有什么特点?

机器学习、大数据、深度学习、云计算等的发展和应用&#xff0c;机器人完成复杂专业任务的能力越来越强。智能化机器人时代的到来&#xff0c;进一步拓宽了服务机器人的应用场景和服务模式&#xff0c;人工智能机器人的问世&#xff0c;更使电销机器人进入到了电销行业。我们一…

如何禁用USB存储设备|禁用USB储存和连接手机的方法有哪些?深度解析,四招搞定!

在企业网络安全管理中&#xff0c;禁用USB存储设备和限制手机连接至关重要。这不仅可以防止数据泄露&#xff0c;还能阻止恶意软件通过外部设备入侵。 本文将为你推荐四种行之有效的方法&#xff0c;帮助你全面禁用USB存储设备和连接手机的功能&#xff0c;让企业数据安全更有…

【SpringCloud应用框架】GateWay网关

Spring Cloud Alibaba 之初识GateWay网关 文章目录 一、网关介绍二、网关对比三、GateWay基本概念&#xff1a;执行流程&#xff1a; 总结 一、网关介绍 在微服务架构中&#xff0c;一个系统会被拆分为多个微服务。如果没有网关存在&#xff0c;我们只能在客户端记录梅哥为服务…

echarts横向柱状图让Y轴的名字在柱状图上方展示

效果 代码 myEcharts(){// 基于准备好的dom&#xff0c;初始化echarts实例this.myChart echarts.init(this.$refs.rankingList);// 指定图表的配置项和数据var option { title: { }, tooltip: { trigger: axis, axisPointer: { type: shadow } }, legend: { …

中职院校智能物联网应用专业群建设方案

一、引言 随着信息技术的飞速发展&#xff0c;智能物联网&#xff08;IoT&#xff09;作为新一代信息技术的重要组成部分&#xff0c;正深刻改变着人们的生活方式、生产模式和社会形态。为积极响应国家“中国制造2025”和“智慧城市”等战略部署&#xff0c;培养适应未来社会需…

开源 AI 智能名片 S2B2C 商城小程序在社区团购中的应用与价值

摘要&#xff1a;本文探讨了开源 AI 智能名片 S2B2C 商城小程序在社区团购中的重要作用。社区团购的团长角色多元&#xff0c;包括小区店主、水站与快递站站长、宝妈等&#xff0c;其用户基础广泛。优秀团长的专业引导和良好服务至关重要&#xff0c;而开源 AI 智能名片 S2B2C …

YOLOv8改进实战 | 引入混合局部通道注意力模块MLCA(2023轻量级)

YOLOv8专栏导航:点击此处跳转 前言 YOLOv8 是由 YOLOv5 的发布者 Ultralytics 发布的最新版本的 YOLO。它可用于对象检测、分割、分类任务以及大型数据集的学习,并且可以在包括 CPU 和 GPU 在内的各种硬件上执行。 YOLOv8 是一种尖端的、最先进的 (SOTA) 模型,它建立在以前…

YoloV8 single channel train + Onnx trans

yolov8目前不支持单通道图片训练&#xff0c;需要修改后才能支持。本文将介绍如何修改yolov8代码&#xff0c;来训练单通道图的yolov8模型&#xff0c;以及使用onnx进行模型转换的简单实践。 1、修改代码 git diff ultralytics/utils/checks.py diff --git a/ultralytics/utils…

Spire.PDF for .NET【文档操作】演示:创建 PDF 文档

通过代码创建 PDF 文档具有多种优势。例如&#xff0c;您可以轻松合并动态内容&#xff0c;如用户输入、数据库记录或实时数据。基于代码的 PDF 生成允许更大的自定义和自动化&#xff0c;最大限度地减少创建高度定制文档时的手动干预。在本文中&#xff0c;您将学习如何使用Sp…

【陪诊系统-PC管理端】axios的二次封装

二次封装axios 引入axios创建axios实例&#xff0c;添加配置信息&#xff0c;这里主要设置基础url和请求超时时间给上述创建的实例添加拦截器&#xff0c;对请求、响应分别进行拦截 根据接口文档显示&#xff0c;当登录成功后&#xff0c;每次请求陪诊师、订单信息都需要携带t…

fastchat与autogen使用要点澄清

说明&#xff1a; 本文重点是想使用autogen构建智能体&#xff0c;并且想要通过加载本地模型来构建&#xff0c;以灵活使用。但是autogen重点是以API调用支持openai, mistral等大模型使用的&#xff0c;对于使用国内的一些模型不是那么友好方便。然后在查找方法的过程中&#x…

一篇常见第三方库之以及详细使用示例教程

作者&#xff1a;郭震 我们介绍了几个常用的 Python 第三方库,包括 NumPy、Pandas、Matplotlib 和 Requests.本篇将通过一些简单的示例来演示如何有效地使用这些库,以帮助小白理解它们的基本用法.通过这些案例,你可以直观感受到这些库在日常编程中的价值. NumPy NumPy 是一个强…

规控面试复盘

目录 前言 一、京东方 1、CPP和C的区别是什么? 2、讲一下的ROS的话题通信 二、Momenta(泊车部门实习面试) 1、MPC的预测时间步是多少? 2、MPC的代价函数考虑的是什么? 三、九识 1、智能指针有哪些优缺点? 优点: 缺点: 2、Protobuf的数据传输效率为什么更高…

【陪诊系统-PC管理端】动态路由

先说说这里为什么要使用动态路由&#xff1f; 因为前面的菜单管理功能模块中&#xff0c;可以创建或修改不同权限&#xff0c;当前登录账号可以绑定不同的权限&#xff0c;不同权限能访问的功能页面不同&#xff0c;所以使用动态路由来控制。 而登录成功后&#xff0c;服务器…