代码随想录-Day45

198. 打家劫舍

你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。

给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。

示例 1:

输入:[1,2,3,1]
输出:4
解释:偷窃 1 号房屋 (金额 = 1) ,然后偷窃 3 号房屋 (金额 = 3)。
偷窃到的最高金额 = 1 + 3 = 4 。
示例 2:

输入:[2,7,9,3,1]
输出:12
解释:偷窃 1 号房屋 (金额 = 2), 偷窃 3 号房屋 (金额 = 9),接着偷窃 5 号房屋 (金额 = 1)。
偷窃到的最高金额 = 2 + 9 + 1 = 12 。
在这里插入图片描述

方法一:

// 动态规划
class Solution {public int rob(int[] nums) {if (nums == null || nums.length == 0) return 0;if (nums.length == 1) return nums[0];int[] dp = new int[nums.length];dp[0] = nums[0];dp[1] = Math.max(dp[0], nums[1]);for (int i = 2; i < nums.length; i++) {dp[i] = Math.max(dp[i - 1], dp[i - 2] + nums[i]);}return dp[nums.length - 1];}
}

这段代码是一个Java类,实现了一个名为Solution的类,其中包含一个名为rob的公共方法。这个方法使用动态规划算法来解决“打家劫舍”问题(LeetCode上的第198题)。这个问题描述的是:你是一个小偷,沿街有一排房子,每个房子都有一定数量的钱。相邻的房子有防盗系统连接,如果两间相邻的房子都被抢劫,则会自动联系警察。给定一个整数数组 nums,代表每间房子存放的金额,返回在不触动警报的情况下,你能抢劫到的最大金额。

在这个方法中:

  • 首先检查输入数组是否为空或长度为0,如果是,则返回0。
  • 如果数组长度为1,直接返回该元素的值。
  • 初始化一个与输入数组长度相同的动态规划数组dp,用于存储计算过程中的最大值。
  • 设置dp[0]dp[1]的初始值。
  • 使用for循环遍历输入数组,从下标2开始,对于每个位置i,dp[i]等于dp[i - 1]dp[i - 2] + nums[i]中的较大值。
  • 最后返回dp数组的最后一个元素,即为最大可抢金额。

这种方法的时间复杂度是O(n),空间复杂度也是O(n),其中n是输入数组的长度。不过,可以进一步优化空间复杂度至O(1),只用两个变量来替代整个dp数组。

方法二:

// 使用滚动数组思想,优化空间
// 分析本题可以发现,所求结果仅依赖于前两种状态,此时可以使用滚动数组思想将空间复杂度降低为3个空间
class Solution {public int rob(int[] nums) {int len = nums.length;if (len == 0) return 0;else if (len == 1) return nums[0];else if (len == 2) return Math.max(nums[0],nums[1]);int[] result = new int[3]; //存放选择的结果result[0] = nums[0];result[1] = Math.max(nums[0],nums[1]);for(int i=2;i<len;i++){result[2] = Math.max(result[0]+nums[i],result[1]);result[0] = result[1];result[1] = result[2];}return result[2];}
}

这段代码同样实现了“打家劫舍”问题的解决方案,但采用了滚动数组的思想来优化空间复杂度。在原版的动态规划解法中,我们使用了一个与输入数组等长的数组来保存中间状态。然而,通过观察动态转移方程,我们可以发现当前状态只依赖于前两个状态,因此没有必要保存所有的历史状态,只需要保留最近的两个状态即可。

在这个优化版本中:

  • 首先进行边界条件判断,处理输入数组为空、只有一个元素或只有两个元素的情况。
  • 创建一个长度为3的数组result来保存最近三个状态的值。
  • 初始化result[0]result[1]的值。
  • 使用for循环遍历输入数组,从下标2开始,对于每个位置i,更新result[2]result[0] + nums[i]result[1]中的较大值。
  • 在每次迭代结束后,将result[0]更新为上一轮的result[1],将result[1]更新为当前轮的result[2]
  • 循环结束后,result[2]即为最大可抢金额。

这种方法的空间复杂度被优化到了O(1),因为无论输入数组的长度如何,都只需要常数级别的额外空间。时间复杂度仍然是O(n),其中n是输入数组的长度。这种优化在处理大规模数据时尤为重要,因为它减少了内存使用,提高了程序的效率。

方法三:

// 进一步对滚动数组的空间优化 dp数组只存与计算相关的两次数据
class Solution {public int rob(int[] nums) {if (nums.length == 1)  {return nums[0];}// 初始化dp数组// 优化空间 dp数组只用2格空间 只记录与当前计算相关的前两个结果int[] dp = new int[2];dp[0] = nums[0];dp[1] = Math.max(nums[0],nums[1]);int res = 0;// 遍历for (int i = 2; i < nums.length; i++) {res = Math.max((dp[0] + nums[i]) , dp[1] );dp[0] = dp[1];dp[1] = res;}// 输出结果return dp[1];}
}

这段代码进一步优化了“打家劫舍”问题的解决方案,其目标是将空间复杂度降至最低。这里使用了一个长度为2的数组dp来存储动态规划过程中所需的最近两个状态,而不是之前示例中长度为3的数组。这样做的原因是,我们只需保存前两个状态的信息,就能计算出下一个状态的值。

具体来说:

  • 首先处理边界情况,当输入数组长度为1时,直接返回该元素的值。
  • 初始化长度为2的dp数组,dp[0]dp[1]分别初始化为数组的前两个元素的值。
  • 声明一个变量res用于临时存储计算结果。
  • 使用for循环遍历输入数组,从下标2开始,对于每个位置i,计算resdp[0] + nums[i]dp[1]中的较大值。
  • 更新dp[0]dp[1]的值,dp[0]更新为上一轮的dp[1]dp[1]更新为当前计算得到的res
  • 循环结束后,dp[1]即为最大可抢金额,作为最终结果返回。

这种方法的空间复杂度进一步优化到了O(1),因为我们只使用了固定大小的数组,无论输入数组的长度如何。时间复杂度仍然是O(n),其中n是输入数组的长度。这种优化策略在处理大数据量时特别有效,因为它极大地减少了内存消耗,同时保持了较高的计算效率。

213. 打家劫舍 II

你是一个专业的小偷,计划偷窃沿街的房屋,每间房内都藏有一定的现金。这个地方所有的房屋都 围成一圈 ,这意味着第一个房屋和最后一个房屋是紧挨着的。同时,相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警 。

给定一个代表每个房屋存放金额的非负整数数组,计算你 在不触动警报装置的情况下 ,今晚能够偷窃到的最高金额。

示例 1:

输入:nums = [2,3,2]
输出:3
解释:你不能先偷窃 1 号房屋(金额 = 2),然后偷窃 3 号房屋(金额 = 2), 因为他们是相邻的。
示例 2:

输入:nums = [1,2,3,1]
输出:4
解释:你可以先偷窃 1 号房屋(金额 = 1),然后偷窃 3 号房屋(金额 = 3)。
偷窃到的最高金额 = 1 + 3 = 4 。
示例 3:

输入:nums = [1,2,3]
输出:3
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

class Solution {public int rob(int[] nums) {if (nums == null || nums.length == 0)return 0;int len = nums.length;if (len == 1)return nums[0];return Math.max(robAction(nums, 0, len - 1), robAction(nums, 1, len));}int robAction(int[] nums, int start, int end) {int x = 0, y = 0, z = 0;for (int i = start; i < end; i++) {y = z;z = Math.max(y, x + nums[i]);x = y;}return z;}
}

这段代码是针对“打家劫舍 II”问题(LeetCode上的第213题)的一个解决方案。这个问题与原始的“打家劫舍”问题(LeetCode上的第198题)类似,但是添加了一个额外的约束:房子排列成一个圈,这意味着第一间房子和最后一间房子是相邻的,不能同时被抢劫。因此,解决问题的方法略有不同。

在代码中:

  • 首先,检查输入数组是否为空或长度为0,如果是,则返回0。
  • 如果输入数组长度为1,直接返回该元素的值。
  • 然后,调用robAction函数两次,第一次考虑从第一个元素到最后一个元素前一个(即不包括最后一个元素),第二次考虑从第二个元素到最后一个元素(即不包括第一个元素)。这是因为如果抢劫了第一个房子,就不能抢劫最后一个房子,反之亦然。
  • 最后,取这两次调用robAction函数返回值中的最大值作为最终结果,因为我们要找的是所有可能情况下的最大抢劫金额。

robAction函数是一个辅助函数,它接受一个整数数组nums以及开始和结束的索引,然后使用滚动数组思想来计算从startend(不包括end)的最大可抢金额。具体来说:

  • 初始化三个变量xyz,分别表示前前一个状态、前一个状态和当前状态的最大可抢金额。
  • 使用for循环遍历数组,从startend - 1,对于每个位置i,更新yz的值。y被更新为上一轮的z,而z被更新为yx + nums[i]中的较大值。
  • 循环结束后,z即为从startend - 1的最大可抢金额。

这种方法的时间复杂度是O(n),空间复杂度是O(1),其中n是输入数组的长度。通过使用滚动数组思想,我们能够有效地减少空间使用,提高程序性能。

337. 打家劫舍 III

小偷又发现了一个新的可行窃的地区。这个地区只有一个入口,我们称之为 root 。

除了 root 之外,每栋房子有且只有一个“父“房子与之相连。一番侦察之后,聪明的小偷意识到“这个地方的所有房屋的排列类似于一棵二叉树”。 如果 两个直接相连的房子在同一天晚上被打劫 ,房屋将自动报警。

给定二叉树的 root 。返回 在不触动警报的情况下 ,小偷能够盗取的最高金额 。
在这里插入图片描述
输入: root = [3,2,3,null,3,null,1]
输出: 7
解释: 小偷一晚能够盗取的最高金额 3 + 3 + 1 = 7
在这里插入图片描述
输入: root = [3,4,5,1,3,null,1]
输出: 9
解释: 小偷一晚能够盗取的最高金额 4 + 5 = 9

方法一:

class Solution {// 1.递归去偷,超时public int rob(TreeNode root) {if (root == null)return 0;int money = root.val;if (root.left != null) {money += rob(root.left.left) + rob(root.left.right);}if (root.right != null) {money += rob(root.right.left) + rob(root.right.right);}return Math.max(money, rob(root.left) + rob(root.right));}

这段代码是解决“打家劫舍 III”问题(LeetCode上的第337题)的一种尝试,但使用了简单的递归方法,这种方法虽然逻辑上正确,但在实际运行时会遇到性能问题,特别是在树的规模较大时,可能会导致超时错误。

在这个问题中,你需要在一个二叉树中最大化你的收益,但你不能抢劫任何具有直接父子关系的节点。给定一棵以TreeNode表示的二叉树的根节点root,返回你能获得的最大金额。

代码中定义的rob方法采用递归方式解决这个问题:

  • 首先,检查根节点是否为空,如果是,则返回0,因为没有节点可以抢劫。
  • 然后,计算抢劫当前节点所能获得的金额money,即当前节点的值加上其左子树和右子树的孙子节点所能提供的最大金额。
  • 接着,递归地计算左子树和右子树不抢劫根节点所能提供的最大金额。
  • 最后,返回money和左右子树不抢劫根节点所能提供的最大金额的较大值。

然而,这种方法存在重复计算的问题,即同一子树会被多次计算,导致时间复杂度过高。为了优化这个问题,可以使用动态规划或记忆化搜索的方法来避免重复计算,将已经计算过的子树的结果缓存起来,从而显著提高算法的效率。

例如,可以使用一个哈希表或者在TreeNode结构中增加一个额外的字段来存储每个节点所能提供的最大金额,这样就可以避免重复计算,将时间复杂度降低到O(n),其中n是树中节点的数量。

方法二:

    // 2.递归去偷,记录状态// 执行用时:3 ms , 在所有 Java 提交中击败了 56.24% 的用户public int rob1(TreeNode root) {Map<TreeNode, Integer> memo = new HashMap<>();return robAction(root, memo);}int robAction(TreeNode root, Map<TreeNode, Integer> memo) {if (root == null)return 0;if (memo.containsKey(root))return memo.get(root);int money = root.val;if (root.left != null) {money += robAction(root.left.left, memo) + robAction(root.left.right, memo);}if (root.right != null) {money += robAction(root.right.left, memo) + robAction(root.right.right, memo);}int res = Math.max(money, robAction(root.left, memo) + robAction(root.right, memo));memo.put(root, res);return res;}

这段代码是对“打家劫舍 III”问题(LeetCode上的第337题)的优化解法,通过引入记忆化搜索(也称为备忘录方法)来避免重复计算,从而显著提高了算法的效率。

在代码中:

  • 定义了一个HashMap叫做memo,用来存储已经计算过的节点及其对应的最大可抢金额,以此来避免重复计算。
  • rob1方法是对外提供的接口,它接收树的根节点作为参数,并返回最大可抢金额。它首先创建一个空的memo哈希表,然后调用robAction方法来计算结果。
  • robAction方法是核心的递归函数,它接收一个树节点和memo哈希表作为参数。如果当前节点已经在memo中,直接返回对应的值;否则,计算当前节点的最大可抢金额,将结果存储到memo中,并返回。

具体来说,在robAction方法中:

  • 如果节点为空,返回0。
  • 如果memo中已经存在当前节点的值,直接返回该值。
  • 计算抢劫当前节点所能获得的金额money,即当前节点的值加上其左子树和右子树的孙子节点所能提供的最大金额。
  • 递归地计算左子树和右子树不抢劫根节点所能提供的最大金额。
  • 将计算出的最大金额res存储到memo中,并返回。

通过这种方式,每个节点只被计算一次,避免了原始递归方法中的大量重复计算,从而将时间复杂度降低到O(n),其中n是树中节点的数量。空间复杂度主要由memo哈希表决定,最坏情况下为O(n),即所有节点都需要被存储。这种优化使得算法在处理大规模数据时表现更佳,避免了超时错误。

方法三:

    // 3.状态标记递归// 执行用时:0 ms , 在所有 Java 提交中击败了 100% 的用户// 不偷:Max(左孩子不偷,左孩子偷) + Max(右孩子不偷,右孩子偷)// root[0] = Math.max(rob(root.left)[0], rob(root.left)[1]) +// Math.max(rob(root.right)[0], rob(root.right)[1])// 偷:左孩子不偷+ 右孩子不偷 + 当前节点偷// root[1] = rob(root.left)[0] + rob(root.right)[0] + root.val;public int rob3(TreeNode root) {int[] res = robAction1(root);return Math.max(res[0], res[1]);}int[] robAction1(TreeNode root) {int res[] = new int[2];if (root == null)return res;int[] left = robAction1(root.left);int[] right = robAction1(root.right);res[0] = Math.max(left[0], left[1]) + Math.max(right[0], right[1]);res[1] = root.val + left[0] + right[0];return res;}
}

这段代码提供了一种解决“打家劫舍 III”问题(LeetCode上的第337题)的高效方法,采用了状态标记的递归策略。这种方法不仅避免了重复计算,还通过在每次递归调用中返回两个状态信息(偷与不偷的最大金额),从而简化了后续的决策过程。

在代码中:

  • rob3方法是主入口,它调用robAction1方法并返回最终的最大可抢金额。robAction1方法返回一个长度为2的数组,其中第一个元素表示不抢劫当前节点时的最大金额,第二个元素表示抢劫当前节点时的最大金额。
  • robAction1方法实现了核心的递归逻辑,它接收一个树节点作为参数,递归地计算其左右子树的状态,并基于这些状态计算当前节点的两个状态。

具体来说,在robAction1方法中:

  • 如果节点为空,返回一个全是0的数组。
  • 对于当前节点,递归地获取其左右子树的状态信息。
  • 根据左右子树的状态信息,计算当前节点的两个状态:
    • res[0]表示不抢劫当前节点时的最大金额,等于左右子树中偷与不偷的最大金额之和的较大值。
    • res[1]表示抢劫当前节点时的最大金额,等于当前节点的值加上左右子树不抢劫时的最大金额之和。

最后,rob3方法返回robAction1方法返回的数组中两个元素的较大值,即整个树的最大可抢金额。

这种方法的时间复杂度为O(n),空间复杂度也为O(n),其中n是树中节点的数量。相比于原始的简单递归方法,这种方法通过避免重复计算显著提高了效率,而且通过返回两个状态信息简化了决策过程,使得代码更加简洁和易于理解。

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

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

相关文章

20240702在飞凌OK3588-C开发板上通过HDMI OUT输出USB3.0接口的热像仪的预览图像

20240702在飞凌OK3588-C开发板上通过HDMI OUT输出USB3.0接口的热像仪的预览图像 2024/7/2 18:19 rootok3588:/# rootok3588:/# rootok3588:/# lsusb Bus 005 Device 001: ID 1d6b:0002 Bus 003 Device 001: ID 1d6b:0001 Bus 001 Device 001: ID 1d6b:0002 Bus 006 Device 00…

将excel表格转换为element table(上)

最近有个功能需要将excel展示到html 界面里面&#xff0c;看是简单的一个需求也是需要费尽心思才完得成 原始数据 想要把excel 读取出来&#xff0c;于是使用xlsl的插件 npm i xlsx通过插件可以获取到已经分析好的数据 然后使用sheet_to_html将数据转换为html 再使用v-htm…

Xorbits inference操作实战

1.操作环境 序号软件版本备注1Windows1.版本&#xff1a;Windows 10 专业版2.版本号&#xff1a;21H23.操作系统内部版本&#xff1a;19044.18892Docker Desktop4.24.2 (124339)3WSLUbuntu 22.04 LTS4Python3.105CUDA12.16Dify0.6.6 Xorbits inference 是一个强大且通用的分布…

day09了 加油

浅拷贝 指向同一个地址空间 右边不可取地址 左边一定是到了具体的位置 右值引用std&#xff1a;&#xff1a; move 相信大家默认构造函数都没有问题&#xff0c;所以就不贴例子了 浅拷贝构造函数 只负责复制地址&#xff0c;而不是真的把完整的内存给它 #include <iostre…

shell 脚本编程

简介&#xff1a;用户通过shell向计算机发送指令的&#xff0c;计算机通过shell给用户返回指令的执行结果 通过shell编程可以达到的效果&#xff1a;提高工作效率、可以实现自动化 需要学习的内容&#xff1a;Linux 、 shell的语法规范 编写shell的流程&#xff1a; 第一步…

数据库系统体系结构-DBMS的三级模式结构、DBMS的工作方式、模式定义语言、二级映射

一、体系结构的概念 1、大多数DBMS遵循三级模式结构 &#xff08;1&#xff09;外模式 &#xff08;2&#xff09;概念模式 &#xff08;3&#xff09;内模式 2、DBMS的体系结构描述的应该是系统的组成结构及其联系以及系统结构的设计和变化的原则等 3、1978年美国国家标…

Java学习 (七) 面向对象--多态、object类

一、多态性 多态在java中的体现是 父类的引用指向子类的对象 格式&#xff1a; 父类类型 变量名 子类对象 1、代码案例 vi Person.java public class Person {public String name;public int age;//新增方法public void eat(){System.out.println("人吃饭");}…

github仓库的基本使用-创建、上传文件、删除

1.第一步 先点击左侧菜单栏的远程仓库 2.点击NEW 3.创建仓库 然后点击右下角的 CREATE 4.点击code 点击SSH,然后我出现了You don’t have any public SSH keys in your GitHub account. You can add a new public key, or try cloning this repository via HTTPS. 1&#xff…

【MySQL备份】Percona XtraBackup加密备份实战篇

目录 1.前言 2.准备工作 2.1.环境信息 2.2.配置/etc/my.cnf文件 2.3.授予root用户BACKUP_ADMIN权限 2.4.生成加密密钥 2.5.配置加密密钥文件 3.加密备份 4.优化加密过程 5.解密加密备份 6.准备加密备份 7.恢复加密备份 7.1.使用rsync进行恢复 7.2.使用xtrabackup命令恢…

深度学习之半监督学习:一文梳理目标检测中的半监督学习策略

什么是半监督目标检测&#xff1f; 传统机器学习根据训练数据集中的标注情况&#xff0c;有着不同的场景&#xff0c;主要包括&#xff1a;监督学习、弱监督学习、弱半监督学习、半监督学习。由于目标检测任务的特殊性&#xff0c;在介绍半监督目标检测方法之前&#xff0c;我…

【驱动篇】龙芯LS2K0300之红外驱动

实验目标 编写HX1838红外接收器驱动&#xff0c;根据接收的波形脉冲解码红外按键键值 模块连接 模块连接&#xff1a;VCC接Pin 2&#xff0c;GND接Pin1&#xff0c;DATA接Pin16 驱动代码 HX1838 GPIO初始化&#xff0c;申请中断&#xff0c;注意&#xff1a;GPIO48默认是给…

2023-2024华为ICT大赛中国区 实践赛网络赛道 全国总决赛 理论部分真题

Part1 数通模块(10题)&#xff1a; 1、如图所示&#xff0c;某园区部署了IPv6进行业务测试&#xff0c;该网络中有4台路由器&#xff0c;运行OSPFv3实现网络的互联互通&#xff0c;以下关于该OSPFv3网络产生的LSA的描述&#xff0c;错误的是哪一项?(单选题) A.R1的LSDB中将存在…

Appium adb 获取appActivity

方法一&#xff08;最简单有效的方法&#xff09; 通过cmd命令&#xff0c;前提是先打开手机中你要获取包名的APP adb devices -l 获取连接设备详细信息 adb shell dumpsys activity | grep mFocusedActivity 有时获取到的不是真实的Activity 方法二 adb shell monkey -p …

【瑞吉外卖 | day01】项目介绍+后台登录退出功能

文章目录 瑞吉外卖 — day011. 所需知识2. 软件开发整体介绍2.1 软件开发流程2.2 角色分工2.3 软件环境 3. 瑞吉外卖项目介绍3.1 项目介绍3.2 产品原型展示3.3 技术选型3.4 功能架构3.5 角色 4. 开发环境搭建4.1 数据库环境搭建4.2 Maven项目构建 5. 后台系统登录功能5.1 创建需…

会声会影2024破解版下载 让视频编辑更简单、更有趣

在数字时代&#xff0c;视频已经成为我们生活中不可或缺的一部分。无论是记录生活、分享快乐&#xff0c;还是宣传产品、传递信息&#xff0c;视频都扮演着重要的角色。然而&#xff0c;对于很多人来说&#xff0c;视频编辑却是一个让人望而却步的领域。复杂的软件操作、繁琐的…

容器安全:等保合规性的基石

随着云计算和微服务架构的蓬勃发展&#xff0c;容器技术已经成为现代IT基础设施不可或缺的一部分。在网络安全等级保护制度&#xff08;等保&#xff09;的框架下&#xff0c;容器安全的要求日益凸显&#xff0c;成为等保合规性的基石。本文将深入探讨容器安全在等保中的重要性…

爽!强化学习+注意力机制,吞吐量提升了10多倍!

通过引入注意力机制&#xff0c;强化学习模型不仅能够更加高效地处理复杂的环境和任务&#xff0c;还能在学习和决策过程中实现更高的精度和适应性。 因此这种结合迅速成为了各大领域的研究热点&#xff0c;而且已经在实际应用中有了显著的性能提升。比如分散式强化学习框架SA…

在嵌入式商用里面哪款RTOS(实时操作系统)比较多人用?

在开始前刚好我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「嵌入式的资料从专业入门到高级教程」&#xff0c; 点个关注在评论区回复“888”之后私信回复“888”&#xff0c;全部无偿共享给大家&#xff01;&#xff01;&#xff01; 传统的RTOS和嵌入式Linu…

Qt中使用MySQL数据库详解,好用的模块类封装

本文将详细介绍如何在Qt应用程序中集成MySQL数据库&#xff0c;并封装实现好用的mysql数据库操作类。包括环境准备、连接数据库、执行查询及异常处理等关键步骤&#xff0c;同时包含mysql驱动的编译。分享给有需要的小伙伴&#xff0c;喜欢的可以点击收藏。 目录 环境准备 项…

javaSE期末练习题

文章目录 前言一、程序控制1.顺序结构问题描述解题思路题解 2.选择结构2.1 题1问题描述解题思路题解 2.1 题2问题描述解题思路题解 3.循环结构3.1 阶乘的求取问题描述解题思路题解 3.2 水仙花数问题描述解题思路题解 二、数组三、类与对象1.类与对象1.1圆类问题描述解题思路题解…