Leetcode - 周赛410

目录

一,3248. 矩阵中的蛇

二,3249. 统计好节点的数目

三,3250. 单调数组对的数目 I

dfs记忆化

dfs记忆化1:1改递推

四,3251. 单调数组对的数目 II


一,3248. 矩阵中的蛇

本题就是一道纯模拟题,只需要模拟蛇移动后的下标(i,j),最终返回 i * n + j,代码如下:

class Solution {public int finalPositionOfSnake(int n, List<String> commands) {int i = 0, j = 0;for(String x : commands){if("UP".equals(x)){i--;}else if("RIGHT".equals(x)){j++;}else if("DOWN".equals(x)){i++;}else if("LEFT".equals(x)){j--;}}return (i * n) + j;}
}

二,3249. 统计好节点的数目

本题就是一道关于树的问题,画个图理解一下:

可以使用dfs从下往上不断求出每颗子树的节点数,同时判断对于每一个节点,它的子树的节点数是否相同,相同加一,求出答案。

代码如下:

class Solution {public int countGoodNodes(int[][] edges) {int n = edges.length + 1;List<Integer>[] g = new ArrayList[n];Arrays.setAll(g, e->new ArrayList<>());for(int[] e : edges){g[e[0]].add(e[1]);g[e[1]].add(e[0]);}dfs(0, -1, g);return ans;}int ans = 0;int dfs(int x, int fa, List<Integer>[] g){int t = -1;boolean flg = true;int sum = 1;for(int y : g[x]){if(y != fa){//防止遍历已经遍历过的节点int size = dfs(y, x, g) + 1;//记录x的子树节点是数量sum += size;//判断x的子树节点数量是否相同if(t == -1) t = size;else if(t != size) flg = false;}}if(flg) ans++;//如果相同,加一return sum;}
}

三,3250. 单调数组对的数目 I

dfs记忆化

此时我们需要定义dfs,首先一定有一个参数 i 表示下标,同时题目要求arr1数组递增,arr2数组递减,所以我们需要知道arr1,arr2数组的前一个数X,Y,但是题目告诉我们X+Y=nums[i],所以只需要知道X,Y其中一个就行,这里用的是X。定义dfs(i,X):arr1[i-1] = X,arr2[i-1] = nums[i-1] - X时,nums数组在 [i,n-1] 所能组成的单调数组对。

代码如下:

class Solution {int MOD = (int)1e9 + 7;public int countOfPairs(int[] nums) {memo = new int[nums.length][51];for(int i=0; i<nums.length; i++)Arrays.fill(memo[i], -1);int ans = 0;for(int x=0; x<=nums[0]; x++){ans = (ans + dfs(1, x, nums))%MOD; }return ans;}int[][] memo;int dfs(int i, int x, int[] nums){if(i == nums.length) return 1;if(memo[i][x] != -1) return memo[i][x];int res = 0;int y = nums[i-1] - x;//y >= nums[i] - j <= arr2数组是递减的//nums[i-1] - x >= nums[i] - j//j >= nums[i] - nums[i-1] + x//j >= x <= arr1数组是递增的for(int j=Math.max(x, nums[i] - nums[i-1] + x); j<=nums[i]; j++){res = (res + dfs(i+1, j, nums)) % MOD;}return memo[i][x] = res;}
}

dfs记忆化1:1改递推

class Solution {int MOD = (int)1e9 + 7;public int countOfPairs(int[] nums) {int n = nums.length;int[][] f = new int[n+1][51];Arrays.fill(f[n], 1);for(int i=n-1; i>0; i--){for(int x=0; x<=nums[i]; x++){int y = nums[i-1] - x;int res = 0;for(int j=Math.max(x, nums[i] - nums[i-1] + x); j<=nums[i]; j++){res = (res + f[i+1][j]) % MOD;}f[i][x] = res;}}int ans = 0;for(int x=0; x<=nums[0]; x++){ans = (ans + f[1][x])%MOD; }return ans;}
}

对比

四,3251. 单调数组对的数目 II

本题和上一题一样,只不过范围变大了,所以需要进一步优化:

 

代码如下:

class Solution {int MOD = (int)1e9 + 7;public int countOfPairs(int[] nums) {int n = nums.length;int[][] f = new int[n+1][1001];Arrays.fill(f[n], 1);for(int i=n-1; i>0; i--){int[] s = new int[nums[i]+1];s[0] = f[i+1][0];for(int j=1; j<=nums[i]; j++)s[j] = (s[j-1] + f[i+1][j])%MOD;for(int x=0; x<=nums[i]; x++){int y = nums[i-1] - x;//int res = 0;// for(int j=Math.max(x, nums[i] - nums[i-1] + x); j<=nums[i]; j++){//     res = (res + f[i+1][j]) % MOD;// }int t = Math.max(x, nums[i] - nums[i-1] + x)-1;int res = (s[nums[i]] - (t>=0 && t <= nums[i] ? s[t] : 0) + MOD)%MOD;f[i][x] = res;}}int ans = 0;for(int x=0; x<=nums[0]; x++){ans = (ans + f[1][x])%MOD; }return ans;}
}

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

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

相关文章

django高校毕业生就业推荐系统-计算机毕业设计源码26096

摘 要 当前就业市场竞争激烈&#xff0c;高校毕业生面临着就业难的问题&#xff0c;同时企业也面临招聘难、选人难的挑战。为了更好地对接高校毕业生和企业之间的需求&#xff0c;为毕业生提供个性化的就业求着信息&#xff0c;开发一套充分利用Django和Python技术实现的毕业生…

中科院TOP“灌水神刊”合集!年发文量动辄数千篇,TOP的地位,4区的录用率!

【SciencePub学术】本期&#xff0c;给大家推荐几本环境领域的“灌水神刊”&#xff01;均隶属于中科院TOP刊之列&#xff0c;但是每年庞大的发文量致使投稿接收率极高&#xff01;话不多说&#xff0c;想“灌水”的建议收藏&#xff01; 01 年刊文量4000 Journal of Cleaner …

【sgCreateAPIFunction】自定义小工具:敏捷开发→自动化生成API接口方法代码片段脚本(接口方法代码生成工具)

sgCreateAPIFunction源码 <template><!-- 前往https://blog.csdn.net/qq_37860634/article/details/141159084 查看使用说明 --><div :class"$options.name"><div class"sg-head">接口方法生成工具<el-dropdown:show-timeou…

Redis操作--RedisTemplate(一)介绍

一、介绍 1、简介 RedisTemplate 是 Spring Data Redis 提供的一个高级抽象&#xff0c;由 Spring 官方提供的方便操作 Redis 数据库的一个工具类&#xff0c;支持模板设计模式&#xff0c;使得操作 Redis 更加符合 Spring 的编程模型。还支持序列化机制&#xff0c;可以处理…

第二证券:虚拟现实概念强势,博士眼镜三连板,星星科技涨停

虚拟现实概念14日盘中再度走强&#xff0c;到发稿&#xff0c;硕贝德、博士眼镜、星星科技“20cm”涨停&#xff0c;亚世光电、亿道信息、卓翼科技亦涨停&#xff0c;佳禾智能涨超9%。 值得注意的是&#xff0c;博士眼镜已连续3个交易日涨停。公司昨日在出资者互动途径表示&am…

电脑开机后出现bootmgr is missing原因及解决方法

最近有网友问我为什么我电脑开机后出现bootmgr is missing&#xff0c;这个提示意思是:意思是启动管理器丢失&#xff0c;说明bootmgr损坏或者丢失&#xff0c;系统无法读取到这个必要的启动信息导致无法启动。原因有很多&#xff0c;比如我们采用的是uefi引导&#xff0c;而第…

离职保密协议是什么?怎么样才是合法的?如何维护公司权益?

“商贾之道&#xff0c;在于诚信&#xff1b;机密之重&#xff0c;犹胜千金。” 在历史的长河中&#xff0c;商业机密一直是商家兴衰成败的关键。 时至今日&#xff0c;随着科技的飞速发展&#xff0c;信息时代的浪潮更是将商业秘密的保护推向了新的高度。 离职保密协议&…

思科CCIE最新考证流程

CCIE CCIE&#xff0c;全称Cisco Certified Internetwork Expert,是美国Cisco公司于1993年开始推出的专家级认证考试。被全球公认为IT业最权威的认证&#xff0c;是全球Internetworking领域中最顶级的认证证书。 CCIE方向 CCIE主要有六大方向&#xff1a;企业基础架构Enterp…

重修设计模式-行为型-状态模式

重修设计模式-行为型-状态模式 先了解一下状态机的概念&#xff0c;状态机是软件编程中对一种状态场景的抽象表达&#xff0c;构成状态机三要素是&#xff1a;状态&#xff08;State&#xff09;、事件&#xff08;Event&#xff09;、动作&#xff08;Action&#xff09;&…

【测试】趣味五子棋项目测试报告

一、项目概述以及本次测试的目标 本项目是基于Web的五子棋实时对战应用&#xff0c;为用户提供多人实时游戏体验&#xff1b;项目采用了前后端分离的方法来实现&#xff0c;使用了数据库来存储相关的数据&#xff1b;前端主要有四个页面构成&#xff1a;登录页面&#xff0c;注…

多重背包问题

文章目录 朴素算法基本思想代码 二进制优化算法基本思想代码 单调队列优化多重背包基本思想代码 多重背包我们其实可以看成为01背包和完全背包的组合。也可以把多重背包问题只转换成01背包问题&#xff0c;我们一起来看看解题思路。 朴素算法 基本思想 比如第i件物品有s个,我…

作业08.13

一、TCP机械臂测试 通过w(红色臂角度增大)s&#xff08;红色臂角度减小&#xff09;d&#xff08;蓝色臂角度增大&#xff09;a&#xff08;蓝色臂角度减小&#xff09;按键控制机械臂 注意&#xff1a;关闭计算机的杀毒软件&#xff0c;电脑管家&#xff0c;防火墙 1&#x…

CRC校验算法详解、C语言实现

一、前言 1.1 CRC算法介绍 CRC&#xff08;Cyclic Redundancy Check&#xff09;校验算法是一种广泛应用于数据通信和存储系统中的错误检测方法&#xff0c;主要用于检测数据在传输过程中是否发生了改变。CRC算法通过计算一个固定长度的校验码&#xff0c;将该校验码附加到原…

Linux:进程

先了解一下这篇的基础知识 操作系统简述-CSDN博客还有这篇 ok我们来说进程 进程是什么&#xff1f; 在Windows下我们按下EscCtrlShift召唤任务管理器&#xff0c;查看Windows下的进程 我们的进程也是由操作系统管理的&#xff0c;操作系统对进程的管理也是先描述再组织。 …

Docker Hub 镜像代理加速

因为未知原因&#xff0c;docker hub 已经不能正常拉取镜像&#xff0c;可以使用以下代理服务来进行&#xff1a; "https://docker.m.daocloud.io", "https://noohub.ru", "https://huecker.io", "https://dockerhub.timeweb.cloud"…

更深层的理解视觉Transformer, 对视觉Transformer的剖析

写在前面&&笔者的个人理解 目前基于Transformer结构的算法模型已经在计算机视觉&#xff08;CV&#xff09;领域展现出了巨大的影响力。他们在很多基础的计算机视觉任务上都超过了之前的卷积神经网络&#xff08;CNN&#xff09;算法模型&#xff0c;下面是笔者找到的…

无字母绕过webshell

目录 代码 payload构造 php7 php5 构造payload 代码 不可以使用大小写字母、数字和$然后实现eval的注入执行 <?php if(isset($_GET[code])){$code $_GET[code];if(strlen($code)>35){die("Long.");}if(preg_match("/[A-Za-z0-9_$]/",$code))…

JavaEE 的入门

1. 学习JavaEE Java EE(Java Platform Enterprise Edition), Java 平台企业版. 是JavaSE的扩展, ⽤于解决企业级的开 发需求, 所以也可以称之为是⼀组⽤于企业开发的Java技术标准. 所以, 学习JavaEE主要是学习Java在 企业中如何应⽤. 前⾯学习的是Java基础, JavaEE 主要学习Jav…

easyExcel2.1.6自动trim()的问题

环境&#xff1a;easyExcel 2.1.6 问题&#xff1a;easyExcel会自动忽略String中的空格&#xff0c;调用trim()函数&#xff0c;导致excel中的空格失效。 代码如上所示&#xff0c;所以只需要把globalConfiguration的autoTrim()&#xff0c;设置为false即可 那么怎么设置confi…

【区块链+金融服务】河北股权交易所综合金融服务平台 | FISCO BCOS应用案例

区域性股权市场是我国资本市场的重要组成部分&#xff0c;是多层次资本市场体系的基石。河北股权交易所&#xff08;简称&#xff1a;河交所&#xff09; 作为河北省唯一一家区域性股权市场运营机构&#xff0c;打造河北股权交易所综合金融服务平台&#xff0c;将区块链技术与区…