【leetcode刷题第43天】2016.增量元素之间的最大差值、1361.验证二叉树、1601.最多可达成的换楼请求的数目

本文主要是介绍【leetcode刷题第43天】2016.增量元素之间的最大差值、1361.验证二叉树、1601.最多可达成的换楼请求的数目,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第四十三天

2016 增量元素之间的最大差值

给你一个下标从 0 开始的整数数组 nums ,该数组的大小为 n ,请你计算nums[j] - nums[i] 能求得的 最大差值 ,其中 0 <= i < j < nnums[i] < nums[j]

返回 最大差值 。如果不存在满足要求的 ij ,返回 -1

示例 1:

输入:nums = [7,1,5,4]
输出:4
解释:
最大差值出现在 i = 1 且 j = 2 时,nums[j] - nums[i] = 5 - 1 = 4 。
注意,尽管 i = 1 且 j = 0 时 ,nums[j] - nums[i] = 7 - 1 = 6 > 4 ,但 i > j 不满足题面要求,所以 6 不是有效的答案。
方法

记录前缀最小值,然后遍历每一个元素,得到差值,取最大的差值即可。

class Solution {public int maximumDifference(int[] nums) {int res = -1;int[] min = new int[nums.length + 1];min[0] = Integer.MAX_VALUE;for (int i = 1; i <= nums.length; ++i) {if (nums[i - 1] < min[i - 1]) min[i] = nums[i - 1];else min[i] = min[i - 1];res = Math.max(res, nums[i - 1] - min[i - 1] > 0 ? nums[i - 1] - min[i - 1] : -1);}return res;}
}

1361 验证二叉树

二叉树上有 n 个节点,按从 0n - 1 编号,其中节点 i 的两个子节点分别是 leftChild[i]rightChild[i]

只有 所有 节点能够形成且 形成 一颗 有效的二叉树时,返回 true;否则返回 false

如果节点 i 没有左子节点,那么 leftChild[i] 就等于 -1。右子节点也符合该规则。

注意:节点没有值,本问题中仅仅使用节点编号。

方法

首先我们遍历一遍所有节点的左右孩子,找出其中最顶层的父节点,最顶层的父节点满足:它不是任何一个节点的子节点。因此对于最顶层的父节点,当我们遍历所有节点的左右孩子的时候,将这些孩子标记为已访问,最后我们检验一遍所有已经被访问的节点的数量是否为n-1,同时找出那个唯一没有被标记的节点就是最顶层的父节点。

当我们找到了这个父节点之后,我们使用广度有限搜索遍历所有节点的孩子节点,同时将遍历过的节点标记为已访问,最后我们校验所有的节点是否都被访问过,并且只被访问了一次,如果存在没有被访问的节点或者存在一个节点被访问了一次以上,那么就返回false。否则返回true

class Solution {public boolean validateBinaryTreeNodes(int n, int[] leftChild, int[] rightChild) {boolean[] isVisited = new boolean[n];Queue<Integer> queue =new LinkedList<>();int cnt = 0;for (int i = 0; i < n; ++i) {if (leftChild[i] != -1) {if (isVisited[leftChild[i]]) return false;isVisited[leftChild[i]] = true;cnt++;}if (rightChild[i] != -1) {if (isVisited[rightChild[i]]) return false;isVisited[rightChild[i]] = true;cnt++;}}if (cnt != n - 1) return false;for (int i = 0; i < n; ++i) {if (isVisited[i])  isVisited[i] = false;else {queue.offer(i);isVisited[i] = true;}}while (!queue.isEmpty()) {int index = queue.poll();if (leftChild[index] != -1) {if (isVisited[leftChild[index]]) return false;queue.offer(leftChild[index]);isVisited[leftChild[index]] = true;}if (rightChild[index] != -1) {if (isVisited[rightChild[index]]) return false;queue.offer(rightChild[index]);isVisited[rightChild[index]] = true;}}for (boolean flag : isVisited) if (!flag) return false;return true;}
}

1601 最多可达成的换楼请求数目

我们有 n 栋楼,编号从 0n - 1 。每栋楼有若干员工。由于现在是换楼的季节,部分员工想要换一栋楼居住。

给你一个数组 requests ,其中 requests[i] = [fromi, toi] ,表示一个员工请求从编号为 fromi 的楼搬到编号为 toi 的楼。

一开始 所有楼都是满的,所以从请求列表中选出的若干个请求是可行的需要满足 每栋楼员工净变化为 0 。意思是每栋楼 离开 的员工数目 等于 该楼搬入 的员工数数目。比方说 n = 3 且两个员工要离开楼 0 ,一个员工要离开楼 1 ,一个员工要离开楼 2 ,如果该请求列表可行,应该要有两个员工搬入楼 0 ,一个员工搬入楼 1 ,一个员工搬入楼 2

请你从原请求列表中选出若干个请求,使得它们是一个可行的请求列表,并返回所有可行列表中最大请求数目。

输入:n = 5, requests = [[0,1],[1,0],[0,1],[1,2],[2,0],[3,4]]
输出:5
方法

我们使用二进制数来枚举所有可能满足的换楼请求,然后检查这些换楼请求是否合法。

由于换楼请求的数量最多只有16个,我们可以使用一个32位整数的后16位来完成所有情况的枚举。

对于检查函数,出楼会让人数--,进楼会让人数++,保证每一栋楼的净变化人数为0即可。

class Solution {public int maximumRequests(int n, int[][] requests) {int res = 0;for (int choose = (1 << requests.length) - 1; choose > 0; --choose) {if (check(n, choose, requests)) res = Math.max(res, getLength(choose));}return res;}public boolean check(int n,int choose, int[][] requests) {int[] status = new int[n];int index = 0;while (choose > 0) {if ((choose & 1) == 1) {status[requests[index][0]]--;status[requests[index][1]]++;}index++;choose >>= 1;}for (int i : status) if (i != 0) return false;return true;}public int getLength(int check){int res = 0;while (check > 0) { if ((check & 1) == 1) res++; check >>= 1;}return res;}
}

这篇关于【leetcode刷题第43天】2016.增量元素之间的最大差值、1361.验证二叉树、1601.最多可达成的换楼请求的数目的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/907804

相关文章

Java后端接口中提取请求头中的Cookie和Token的方法

《Java后端接口中提取请求头中的Cookie和Token的方法》在现代Web开发中,HTTP请求头(Header)是客户端与服务器之间传递信息的重要方式之一,本文将详细介绍如何在Java后端(以Sp... 目录引言1. 背景1.1 什么是 HTTP 请求头?1.2 为什么需要提取请求头?2. 使用 Spr

如何提高Redis服务器的最大打开文件数限制

《如何提高Redis服务器的最大打开文件数限制》文章讨论了如何提高Redis服务器的最大打开文件数限制,以支持高并发服务,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录如何提高Redis服务器的最大打开文件数限制问题诊断解决步骤1. 修改系统级别的限制2. 为Redis进程特别设置限制

SpringBoot中Get请求和POST请求接收参数示例详解

《SpringBoot中Get请求和POST请求接收参数示例详解》文章详细介绍了SpringBoot中Get请求和POST请求的参数接收方式,包括方法形参接收参数、实体类接收参数、HttpServle... 目录1、Get请求1.1 方法形参接收参数 这种方式一般适用参数比较少的情况,并且前后端参数名称必须

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

hdu1496(用hash思想统计数目)

作为一个刚学hash的孩子,感觉这道题目很不错,灵活的运用的数组的下标。 解题步骤:如果用常规方法解,那么时间复杂度为O(n^4),肯定会超时,然后参考了网上的解题方法,将等式分成两个部分,a*x1^2+b*x2^2和c*x3^2+d*x4^2, 各自作为数组的下标,如果两部分相加为0,则满足等式; 代码如下: #include<iostream>#include<algorithm

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*

PTA求一批整数中出现最多的个位数字

作者 徐镜春 单位 浙江大学 给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。 输入格式: 输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。 输出格式: 在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n

poj 3723 kruscal,反边取最大生成树。

题意: 需要征募女兵N人,男兵M人。 每征募一个人需要花费10000美元,但是如果已经招募的人中有一些关系亲密的人,那么可以少花一些钱。 给出若干的男女之间的1~9999之间的亲密关系度,征募某个人的费用是10000 - (已经征募的人中和自己的亲密度的最大值)。 要求通过适当的招募顺序使得征募所有人的费用最小。 解析: 先设想无向图,在征募某个人a时,如果使用了a和b之间的关系

poj 3258 二分最小值最大

题意: 有一些石头排成一条线,第一个和最后一个不能去掉。 其余的共可以去掉m块,要使去掉后石头间距的最小值最大。 解析: 二分石头,最小值最大。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <c