Java面试题中高级,java引用数据类型和基本数据类型区别

4步套路,解决动态规划问题

1、确定问题状态

  • 提炼最后一步
  • 的问题转化

2、转移方程,把问题方程化
3、按照实际逻辑设置初始条件和边界情况
4、确定计算顺序并求解

结合实例感受下:

你有三种硬币,分别面值2元,5元和7元,每种硬币都有足够多。买一本书需要27元。如何用最少的硬币组合正好付清,不需要对方找钱?

关键词“用最小的硬币组合正好付清”——“最小的组合”,求最值问题,动态规划

**正常人第一反应思路:**最少硬币组合?优先使用大面值硬币——7+7+7+5=26 额?可求解目标是27啊……改算法——7+7+7+2+2+2=27,总共用了6枚硬币正好27元.实际正确答案:7+5+5+5+5=27,才用了5枚硬币。所以这里贪心算法是不正确的。

套路用起来:

第一步,确定问题状态。

动态规划问题求解需要先开一个数组,并确定数组的每个元素f[i]代表什么,就是确定这个问题的状态。类似于解数学题中,设定X,Y,Z代表什么。

A、确定状态首先提取【最后一步】

最优策略必定是K枚硬币a1, a2,…, aK 面值加起来是27。

找出不影响最优策略的最后一个独立角色,这道问题中,那枚最后的硬币“aK”就是最后一步。把aK提取出来,硬币aK之前的所有硬币面值加总是27- aK因为总体求最硬币数量最小策略,所以拼出27- aK 的硬币数也一定最少(重要设定)。

B、**转化子问题。**最后一步aK提出来之后,我们只要求出“最少用多少枚硬币可以拼出27- aK”就可以了。

这种与原问题内核一致,但是规模变小的问题,叫做子问题。

为简化定义,我们设状态f(X)=最少用多少枚硬币拼出总面值X。我们目前还不知道最后的硬币aK面额多少,但它的面额一定只可能是2/5/7之一。如果aK是2,f(27)应该是f(27-2) + 1 (加上最后这一枚面值2的硬币)如果aK是5,f(27)应该是f(27-5) + 1 (加上最后这一枚面值5的硬币)如果aK是7,f(27)应该是f(27-7) + 1 (加上最后这一枚面值7的硬币)除此以外,没有其他的可能了。

至此,通过找到原问题最后一步,并将其转化为子问题。为求面值总额27的最小的硬币组合数的状态就形成了,用以下函数表示:

f(27) = min{f(27-2)+1, f(27-5)+1, f(27-7)+1}

第二步,转移方程,把问题方程化。

f[X] = min{f[X-2]+1, f[X-5]+1, f[X-7]+1}(动态规划都是要开数组,所以这里改用方括号表示)

实际面试中求解动态规划类问题,正确列出转移方程正确基本上就解决一半了。

但是请问:这与递归有什么不同??

递归的解法:

// f(X)返回最少用多少枚硬币拼出Xint f(int X) {// 0元钱只要0枚硬币if (X == 0) return 0;// 初始化用无穷大(为什么是正无穷?)int res = MAX_VALUE;// 最后一枚硬币是2元if (X >= 2) {res = Math.min(f(X – 2) + 1, res);}// 最后一枚硬币是5元if (X >= 5) {res = Math.min(f(X – 5) + 1, res);}// 最后一枚硬币是7元if (X >= 7) {res = Math.min(f(X – 7) + 1, res);}return res;}

执行图如下:

要算f(27),就要递归f(25)、f(22)、f(20),然后下边依次递归……(三角形表示)。

问题明显——重复递归太多。

这是求f(27),还可以勉强递归。如果求f(100)呢?简直是天文数字。最终结果就是递归超市。

求总体最值,一定优先考虑动态规划不要憨憨的去递归。

插入一下~

需要掌握的动态规划面试解题技巧还包括坐标型、位操型、序列型、博弈型、背包型、双序列以及一些高难面试题解。

本文篇幅有限无法逐一讲清,大家来白嫖我的在线分享吧(纯干货)。

第三步,按照实际逻辑设置边界情况和初始条件。

**【必做】**否则即使转移方程正确也大概率无法跑通代码。

f[X] = min{f[X-2]+1, f[X-5]+1, f[X-7]+1}的边界情况是[x-2]/[x-5]/[x-7]不能小于0(硬币面值为正),也不能高于27。

故对边界情况设定如下:

如果硬币面值不能组合出Y,就定义f[Y]=正无穷例如f[-1]=f[-2]=…=正无穷;f[1] =min{f[-1]+1, f[-4]+1,f[-6]+1}=正无穷,

**特殊情况:**本题的F[0]对应的情况为F[-2]、F[-5]、F[-7],按照上文的边界情况设定结果是正无穷。

但是实际上F[0]的结果是存在的(即使用0个硬币的情况下),F[0]=0。可是按照我们刚刚的设定,F[0]=F[0-2]+1= F[-2]+1=正无穷。

岂不是矛盾?

这种用转移方程无法计算,但是又实际存在的情况,就必须通过手动定义。

这里手动强制定义初始条件为:F[0]=0.

而从0之后的数值是没矛盾的,比如F[1]= F[1-2]+1= F[-1]+1=正无穷(正无穷加任何数结果还是正无穷);F[2]= F[2-2]+1= F[0]+1=1……

第四步,确定计算顺序并计算求解

那么开始计算时,是从F[1]、F[2]开始呢?还是从F[27]、F[26]开始呢?

判断计算顺序正确与否的原则是:当我们要计算F[X](等式左边,如F[10])的时候,等式右边(f[X-2], f[X-5], f[X-7]等)都是已经得到结果的状态,这个计算顺序就是OK的。

实际就是从小到大的计算方式(偶有例外的情况我们后边再讲)。

例如我们算到F[12]的时候,发现F[11]、F[10]、F[9]都已经算过了,这种算法就是对的;而开始算F[27]的时候,发现F[26]还没有算,这样的顺序就是错的。

很显然这样的情况下写一个FOR循环就够了。

回到这道题,采用动态规划的算法,每一步只尝试三种硬币,一共进行了27步。算法时间复杂度(即需要进行的步数)为27*3。

与递归相比,没有任何重复计算。

**原题练习及实际代码:**这道题是lintcode编号669的Coin Change问题。代码如下:

public int coinChange(int[] A, int M){// A = [2,5,7]// M = 27int[] f = new int[M + 1];int n = A.length; // 硬币的种类// 初始化, 0个硬币f[0] = 0;// f[1], f[2], ... , f[27] = Integer.MAX_VALUEfor (int i = 1; i <= M; i++){f[i] = Integer.MAX_VALUE;}for (int i = 1; i <= M; i++){// 使用第j个硬币 A[j]// f[i] = min{f[i-A[0]]+1, ... , f[i-A[n-1]]+1}for (int j = 0; j < n; ++j){// 如果通过放这个硬币能够达到重量iif (i >= A[j] && f[i - A[j]] != Integer.MAX_VALUE) {// 获得i的重量的硬币数就可能是获得i-A[j]重量硬币数的方案+1// 拿这个方案数量与原本的方案数打擂台,取最小值就行f[i] = Math.min(f[i - A[j]] + 1, f[i]);}}}if (f[M] == Integer.MAX_VALUE){return -1;}return f[M];}

最后总结:

1、这是求最值问题,用动态规划方式求解。2、进入求解过程,先确定问题状态

  • 提炼最后一步
    (最优策略中使用的最后一枚硬币aK)
    -子问题转化 (最少的硬币拼出更小的面值27-aK)
    3、构建转移方程 f[X] = min{f[X-2]+1, f[X-5]+1, f[X-7]+1}
    (求min是因为题目要求求最小)
    4、设置初始条件和边界情况 f[0] = 0, 如果不能拼出Y,f[Y]=正无穷
    5、确定计算顺序并计算求解
    f[0], f[1], f[2]……

实际上按照以上4步套路,基本上可以应对绝对大多数的动态规划面试题。

总结

在这里,由于面试中MySQL问的比较多,因此也就在此以MySQL为例为大家总结分享。但是你要学习的往往不止这一点,还有一些主流框架的使用,Spring源码的学习,Mybatis源码的学习等等都是需要掌握的,我也把这些知识点都整理起来了,有需要的朋友可以**【转发+关注】后点击这里免费领取!**

面试真题

等都是需要掌握的,我也把这些知识点都整理起来了,有需要的朋友可以**【转发+关注】后点击这里免费领取!**

[外链图片转存中…(img-OtYDajkq-1625571563748)]

Spring源码笔记

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

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

相关文章

小企业服务器设置位置,小企业服务器配置

小企业服务器配置 内容精选换一换使用企业主机安全服务&#xff0c;您将可以同时使用消息通知服务接收告警通知信息&#xff0c;使用统一身份认证服务管理用户权限&#xff0c;利用云审计服务审计用户行为。企业主机安全服务的Agent软件可安装在华为云ECS服务器/BMS服务器/HECS…

Java面试题及答案2020,kafka教程分享

三面头条 面试岗位是后台研发工程师&#xff0c;地点选择了上海&#xff0c;通过大佬内推&#xff0c;跳过死亡笔试&#xff0c;加上疫情期间&#xff0c;所以直接视频面&#xff0c;从3点开始&#xff0c;断断续续到晚上8点结束。 一共三轮技术面试&#xff0c;每一轮都要写代…

Java面试题及答案2020,安卓java编程软件app

一面&#xff08;一个半小时&#xff09; 首先自我介绍 了解Web层开发&#xff1f;数据库索引了解么&#xff1f;聚簇索引&#xff0c;非聚簇索引&#xff1f;索引分类&#xff1f; 了解数据库都由哪些引擎&#xff1f;分别有什么区别和使用场景&#xff1f; 了解分布式&…

Java面试题及答案,java对外提供接口

Redis简介 Redis与Memcached区别Redis优点Redis缺点 Redis数据类型 StringHashListSetSorted set Redis事务 MULTI&EXEC&#xff08;原子执行&#xff0c;并非互斥&#xff09;WATCH&UNWATCH&#xff08;原子执行乐观锁&#xff09; Redis分布式锁 排他锁 SETNX带有…

Java面试题及答案,我把所有Java框架整理成了PDF

第1章 初识Redis 初识Redis&#xff0c;带领读者进入Redis的世界&#xff0c;了解它的前世今生、众多特性、应用场景、安装配置、简单使用&#xff0c;最后对Redis发展过程中的重要版本进行说明&#xff0c;可以让读者对Redis有一个全面的认识。 1.1Redis特性 1.2Redis使用场景…

Java面试题库,java四舍五入保留小数点后两位输出

第5章 持久化 持久化&#xff0c;Redis的持久化功能有效避免因进程退出造成的数据丢失问题&#xff0c;本章首先介绍RDB和AOF两种持久化配置和运行流程&#xff0c;其次对常见的持久化问题进行定位和优化&#xff0c;最后结合Redis常见的单机多实例部署场景进行优化。 5.1 RDB …

Java面试题库,java核心技术第十版下载

阿里巴巴篇 1.扎实的计算机专业基础&#xff0c;包括算法和数据结构&#xff0c;操作系统&#xff0c;计算机网络&#xff0c;计算机体系结构&#xff0c;数据库等2.具有扎实的Java编程基础&#xff0c;理解IO、多线程等基础框架3.熟练使用Linux系统的常用命令及shell有一定了…

Java面试题整理,java常用排序算法图解

微服务架构 ①微服务概念&#xff1a; ②Spring Cloud微服务架构&#xff1a; 海量数据处理 ①&#xff1a;经典的海量数据处理面试题 高可用架构 ①基于 Hystrix 实现高可用&#xff1a; ②限流&#xff1a; ③熔断&#xff1a; 高并发架构 ①消息队列&#xff1a; ②搜索…

Java面试题2020,单击更改以将java安装到其他文件夹

工作的前两年 如果你不能拼爹&#xff0c;或者不想拼爹&#xff0c;最好的方法是拼实力。 合抱之木&#xff0c;生于毫末&#xff1b;九层之台&#xff0c;起于垒土&#xff1b;千里之行&#xff0c;始于足下。 所以&#xff0c;你必须要从基层做起。当然&#xff0c;所谓的基…

Java面试题中高级,javaif循环语句

微服务是什么 微服务起源于2005年Peter Rodgers博士在云端运算博览会提出的微Web服务(Micro-Web-Service)&#xff0c;根本思想类似于Unix的管道设计理念。2014年&#xff0c;由Martin Fowler 与 James Lewis共同提出了微服务的概念&#xff0c;定义了微服务架构风格是一种通过…

Java面试题及答案2020,java数组循环赋值

什么是ACID&#xff1f; 事务的定义和实现一直随着数据管理的发展在演进&#xff0c;当计算机越来越强大&#xff0c;它们就能够被用来管理越来越多数据&#xff0c;最终&#xff0c;多个用户可以在一台计算机上共享数据&#xff0c;这就导致了一个问题&#xff0c;当一个用户…

Java面试题及答案,java底层实现原理

工厂方法模式 Spring 框架使用工厂模式来实现 Spring 容器的 BeanFactory 和 ApplicationContext 接口。Spring 容器基于工厂模式为 Spring 应用程序创建 bean&#xff0c;并管理着每一个 bean 的生命周期。BeanFactory 和 ApplicationContext 是工厂接口&#xff0c;并且在 S…

Java面试题及答案,mysql可视化工具

为什么阿里巴巴的持久层抛弃hibernate&#xff0c;采用MyBatis框架&#xff1f; 原因大概有以下4点&#xff1a; 尤其是需要处理大量数据或者大并发情况的网站服务&#xff0c;这也阿里选择MyBatis的原因。 MyBatis整体架构 不多讲&#xff0c;先看目录图 MyBatis源码笔记文档…

Java面试题及答案,mysql类型

面试真题以及解析 Web&#xff0c;RESTful API 在微服务中的作用是什么&#xff1f; 微服务架构基于一个概念&#xff0c;其中所有服务应该能够彼此交互以构建业务功能。因此&#xff0c;要实现这一点&#xff0c;每个微服务必须具有接口。这使得 Web API 成为微服务的一个非…

Java面试题库,java导入图片

自我管理 谨言慎行 畅销书《影响力》提到&#xff0c;因为影响力的巨大差异&#xff0c;娱乐明星比科学家收入高几万倍。技术经理管理了N个人&#xff0c;影响力就是N倍&#xff0c;如果言行不端&#xff0c;造成的影响是基层人员的N倍。博主有过一个上级&#xff0c;把粗鲁当…

Java面试题库,java每天定时任务

正文 做了 3~5 年编程开发&#xff0c;你已经积累了不少项目经验&#xff0c;扩宽了技术广度&#xff0c;也许已发力成为团队管理者。到了这个阶段&#xff0c;大家却常有这种感受&#xff1a;感觉自己卡在瓶颈进步缓慢&#xff0c;技术水平很难像早期一样实现大幅突破&#x…

Java面试题整理,docker可视化监控工具

1关于MySQL&#xff0c;面试官会问哪些问题&#xff1f; 第一个&#xff1a;MySQ性能优化最佳实践21个&#xff08;有具体的解释&#xff09;你知道哪些&#xff1f; 为查询缓存优化你的查询 EXPLAIN你的SELECT查询 当只要一行数据时使用LIMIT 1 为搜索字段建索引 在Join表…

Java面试题整理,一线互联网公司java面试核心知识点

SpringBoot经典之作 进入Spring Boot世界 准备开发环境搭建开发工具 基础 Spring Boot基础分层开发Web应用程序响应式编程 进阶 Spring Boot进阶用ORM操作SQL数据库接口架构风格——RESTful集成安全框架&#xff0c;实现安全认证和授权集成Redis&#xff0c;实现高并发集成R…

Java开发框架!阿里大牛亲手操刀微服务架构实战

java基础 1.1java的8种基本数据类型装箱拆箱 1.2重写重载封装继承多态 1.3 Stack Queue 1.7 Concurrent包 1.8面向对象 1.9 String StringBuffer StringBuilder hashcode equ 1.10 java文件读取 1.11 Java反射 1.12 JDK NDK JRE JNI 1.13 static和final的区别 1.14 …

Java开发框架!高级java工程师简历模板

第一部分必读系列&#xff1a; 01.学习算法和刷题的思路指南 02.学习数据结构和算法读什么书 03.动态规划解题套路框架 04.动态规划答疑篇 05.动态规划答疑篇 06.回溯算法解题套路框架 07.二分查找解题套路框架 08.滑动窗口解题套路框架 09.双指针技巧总结 10.BFS算法套…