LeetCode 628. 三个数的最大乘积 java版

devtools/2024/9/23 1:26:02/

1. 官网:

. - 力扣(LeetCode)

2. 题目:

给你一个整型数组 nums ,在数组中找出由三个数组成的最大乘积,并输出这个乘积。

示例 1:

输入:nums = [1,2,3]
输出:6

示例 2:

输入:nums = [1,2,3,4]
输出:24

示例 3:

输入:nums = [-1,-2,-3]
输出:-6

提示:

  • 3 <= nums.length <= 104
  • -1000 <= nums[i] <= 1000

3. 解:

    思路:1. 给数组排序 (Arrays.sort),如果没有这个sort 你会用什么排序呢?

               2. 取数组最大三个数相乘

              3. 两个负数和一个正整数乘积,也需要加入判断

package com.nami.algorithm.study.maxnum;import java.util.Arrays;/*** 描述: 三个数的最大乘积** @Author: lbc* @Date: 2024-04-16 16:09* @email: 594599620@qq.com* @Description: keep coding*/
public class Solution {/*** 正常思路 排序后,最大三个数乘积即可* 如果没有例子,两个负数和一个整数 这个条件容易遗忘。就会变成 ·1.排序  ·2.return,取最大三个数的乘积** @param nums* @return*/public static int maximumProduct(int[] nums) {// DualPivotQuicksort 包含多种排序,根据数量判断使用 哪种排序算法// 这个sort 方法 比这道题nbArrays.sort(nums);int len = nums.length;return Math.max(nums[0] * nums[1] * nums[len - 1], nums[len - 1] * nums[len - 2] * nums[len - 3]);}public static void main(String[] args) {int[] nums = new int[]{1, 4, 6, 8, 320, 33, -200, -100, 20};System.out.println(maximumProduct(nums));}}

 4. 解2:

     解1的延伸,解1 是排序,找到最小数次最小数最大数次最大数次次最大数,一次遍历找出五个数,可以不用排序算法,再进行判断

          1. 找出五个数

          2. 同上,计算最大数乘积,与最小数 * 次最小数 * 最大数乘积,判断最大值

    public static int maximumProduct(int [] nums) {// 最小值int min1 = Integer.MAX_VALUE;// 次最小值int min2 = Integer.MAX_VALUE;// 最大值int max1 = Integer.MIN_VALUE;// 次大值int max2 = Integer.MIN_VALUE;// 次次大int max3 = Integer.MIN_VALUE;for (int cur : nums) {if (cur < min1) {min2 = min1;min1 = cur;} else if (cur < min2) {min2 = cur;}if (cur > max1) {max3 = max2;max2 = max1;max1 = cur;} else if (cur > max2) {max3 = max2;max2 = cur;} else if (cur > max3) {max3 = cur;}}return Math.max(min1 * min2 * max1, max1 * max2 * max3);}

5. 排序算法: 冒泡,快排,堆排序,插入,希尔排序,桶?哪个是稳定排序?,还记得思路以及实现代码吗?


http://www.ppmy.cn/devtools/4061.html

相关文章

【微信小程序——案例——本地生活(列表页面)】

案例——本地生活&#xff08;列表页面&#xff09; 九宫格中实现导航跳转——以汽车服务为案例&#xff08;之后可以全部实现页面跳转——现在先实现一个&#xff09; 在app.json中添加新页面 修改之前的九宫格view改为navitage 效果图&#xff1a; 动态设置标题内容—…

开发日志2024-04-12

开发日志2024/04/12 1、分店月业绩和年业绩都需要添加为真实数据 **开发思路&#xff1a;**分店下所属的技师的业绩总和 代码实现&#xff1a; 前端 无 后端 //TODO 将技师多对应的积分累加到他所属的分店的月/年累计业绩销量中//TODO 查询技师所对应的分店地址String f…

正则表达式(1)

文章目录 专栏导读1、match2、匹配目标3、通用匹配4、常用匹配规则表格 专栏导读 ✍ 作者简介&#xff1a;i阿极&#xff0c;CSDN 数据分析领域优质创作者&#xff0c;专注于分享python数据分析领域知识。 ✍ 本文录入于《python网络爬虫实战教学》&#xff0c;本专栏针对大学生…

Jmeter redis连接测试

Jmeter连接redis获取数据&#xff0c;一直连不上报错。最后只能通过java代码连接测试&#xff0c;最后只能自己动手。 import redis.clients.jedis.*;import java.io.IOException; import java.util.HashSet; import java.util.Set;/*** 单机版的Jedis连接池的用法*/ public c…

React-RTK

​&#x1f308;个人主页&#xff1a;前端青山 &#x1f525;系列专栏&#xff1a;React篇 &#x1f516;人终将被年少不可得之物困其一生 依旧青山,本期给大家带来React篇专栏内容:React-RTK 目录 1、介绍 2、安装 3、编写RTK使用示例 4、官方提供项目包示例 创建 Redux …

使用【node】创建本地接口

在前端开发的过程中&#xff0c;接口相关的信息一般是由后端处理好返回给前端&#xff0c;但是有时候后端不在的时候想自己写个接口进行测试是非常麻烦的。 node是前端一个不错的写接口工具 一 初始化文件 1 在新建一个空的文件夹node 进入空文件夹在&#xff0c;文件夹的地…

每日两题 / 15. 三数之和 73. 矩阵置零(LeetCode热题100)

15. 三数之和 - 力扣&#xff08;LeetCode&#xff09; 先确定一个数t&#xff0c;对于剩下的两个数&#xff0c;要求两数之和为t的负数 三数之和就退化成了两数之和&#xff0c;两数之和可以用双指针 先排序&#xff0c;左右两个指针&#xff0c;指向的数之和大于目标值&…

mysql多表查询

目录 多表关系 一对多&#xff08;多对一&#xff09; 多对多 一对一 多表查询概述 什么是多表查询 例子&#xff1a; 多表查询的分类&#xff1a; 连接查询&#xff1a; 子查询&#xff1a; 内连接 内连接查询语法&#xff1a; 隐式内连接&#xff1a; 显示内连…