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

2023-10-31 13:48

本文主要是介绍LeetCode 1601. 最多可达成的换楼请求数目,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:

力扣https://leetcode-cn.com/problems/maximum-number-of-achievable-transfer-requests/

 

【分析】直接回溯法遍历所有的request,并用一个cnt数组记录每栋楼里的人数,初始时都是0,如果某个request被选中,那么下标为from的cnt--,下标为to的cnt++。当回溯层数到达request长度时判断cnt是否还是为0。

class Solution {int ans = 0;int k;int[][] req;public void dfs(int t, int j, int[] cnt){if(t == k){int i;for(i = 0; i < cnt.length; i++){if(cnt[i] != 0) break;}if(i == cnt.length) {System.out.println(j);ans = Math.max(ans, j);}}else{int[] tmp = cnt.clone();dfs(t + 1, j, tmp);tmp[req[t][1]] ++;tmp[req[t][0]] --;dfs(t + 1, j + 1, tmp);}}public int maximumRequests(int n, int[][] requests) {int[] cnt = new int[n];req = requests;k = requests.length;dfs(0, 0, cnt);return ans;}
}

需要特别注意!这里的cnt数组要clone一份,不然只传cnt的话下一层修改会影响上一层的cnt。

【改进】加入剪枝,如果剩下的request数目加上先前已经被选择的request数目小于目前的最大值的话直接return出去就行;另外这里的cnt可以不复制一份新的,只要记得在调完dfs后把值复原就行了。

 

class Solution {int ans = 0;int k;int[][] req;public void dfs(int t, int j, int[] cnt){if(t == k){int i;for(i = 0; i < cnt.length; i++){if(cnt[i] != 0) break;}if(i == cnt.length) {System.out.println(j);ans = Math.max(ans, j);}}else{if(j + k - t < ans) return;dfs(t + 1, j, cnt);cnt[req[t][1]] ++;cnt[req[t][0]] --;dfs(t + 1, j + 1, cnt);cnt[req[t][1]] --;cnt[req[t][0]] ++;}}public int maximumRequests(int n, int[][] requests) {int[] cnt = new int[n];req = requests;k = requests.length;dfs(0, 0, cnt);return ans;}
}

这篇关于LeetCode 1601. 最多可达成的换楼请求数目的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

Spring Boot Controller处理HTTP请求体的方法

《SpringBootController处理HTTP请求体的方法》SpringBoot提供了强大的机制来处理不同Content-Type​的HTTP请求体,这主要依赖于HttpMessageCo... 目录一、核心机制:HttpMessageConverter​二、按Content-Type​处理详解1.

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp