这是悦乐书的第222次更新,第235篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第89题(顺位题号是414)。给定非空的整数数组,返回此数组中的第三个最大数字。如果不存在,则返回最大数量。时间复杂度必须在O(n)中。例如:

输入:[3,2,1]

输出:1

说明:第三个最大值为1。

输入:[1,2]

输出:2

说明:第三个最大值不存在,因此返回最大值2。

输入:[2,2,3,1]

输出:1

说明:请注意,此处的第三个最大值表示第三个最大不同的数字。值为2的两个数字都被视为第二个最大值。

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

使用包装类Integer,分别定义第一大、第二大、第三大三个变量。foreach遍历数组中的每个元素,如果当前元素与三个变量中的任意一个相等,就进入下一次循环。如果第一大为null或者当前元素大于第一大,那么将三个数轮流交换位置,第三大为原第二大,第二大为原第一大,第一大为当前元素。如果第二大为null或者当前元素大于第二大,那么第三大为原第二大,第二大为当前元素。如果第三大为null或者当前元素大于第三大,那么第三大为当前元素。最后,如果第三大为null,就返回第一大,反之返回第三大。

此解法时间复杂度是O(n),空间复杂度是O(1)。

public int thirdMax(int[] nums) {
Integer max_one = null;
Integer max_two = null;
Integer max_three = null;
for (Integer n : nums) {
if (n.equals(max_one) || n.equals(max_two) || n.equals(max_three)) {
continue;
}
if (max_one == null || n > max_one) {
max_three = max_two;
max_two = max_one;
max_one = n;
} else if(max_two == null || n > max_two) {
max_three = max_two;
max_two = n;
} else if (max_three == null || n > max_three) {
max_three = n;
}
}
return max_three == null ? max_one : max_three;
}

03 第二种解法

此解法的思路和第一种解法的思路一致,只是将包装类Integer换成了long类型,去掉了equals方法。

此解法时间复杂度是O(n),空间复杂度是O(1)。

public int thirdMax2(int[] nums) {
long max_one = Long.MIN_VALUE;
long max_two = Long.MIN_VALUE;
long max_three = Long.MIN_VALUE;
for (int n : nums) {
if (n == max_one || n == max_two || n == max_three) {
continue;
}
if (max_one == Long.MIN_VALUE || n > max_one) {
max_three = max_two;
max_two = max_one;
max_one = n;
} else if (max_two == Long.MIN_VALUE || n > max_two) {
max_three = max_two;
max_two = n;
} else if (max_three == Long.MIN_VALUE || n > max_three) {
max_three = n;
}
}
return max_three == Long.MIN_VALUE ? (int)max_one : (int)max_three;
}

04 第三种解法

此解法和上面两种思路类似,但是将首次相等的判断做了调整,如果当前元素大于等于第一大或第二大或第三大时,再去继续判断是不是大于第一大或第二大或第三大,满足才交换位置。

此解法时间复杂度是O(n),空间复杂度是O(1)。

public int thirdMax3(int[] nums) {
long one = Long.MIN_VALUE;
long two = Long.MIN_VALUE;
long three = Long.MIN_VALUE;
for (int n : nums) {
if (n >= one) {
if (n > one) {
three = two;
two = one;
one = n;
}
} else if (n >= two) {
if (n > two) {
three = two;
two = n;
}
} else if (n >= three) {
if (n > three) {
three = n;
}
}
}
return three == Long.MIN_VALUE ? (int)one : (int)three;
}

05 第四种解法

特殊情况:当数组中只有一个元素时,此时第三大的值就是该元素;当数组中只有两个元素,那么第三大元素就是两元素中最大的一个。

正常情况:使用Arrays.sort()方法,先将数组排序,从小到大排列,定义一个变量count,从后往前遍历,如果当前元素和前一个元素相等,就跳出当前循环进入下一次循环,否则count就加1。然后判断count是否等于2,因为第一大和第二大不相等时,count才加1,第二大和第三大不相等时,再加1,所以当count等于2时,就表示遇到了第三大的数,对应的索引是i-1,不是i。如果不满足,最后返回第一大的数即可。

此解法的时间复杂度是O(nlog(n)),空间复杂度是O(1)。

public int thirdMax4(int[] nums) {
int length = nums.length;
if (length == 1) {
return nums[0];
}
if (length == 2) {
return Math.max(nums[0], nums[1]);
}
Arrays.sort(nums);
int count = 0;
for (int i=length-1; i>0; i--) {
if (nums[i] == nums[i-1]) {
continue;
} else {
count++;
}
if (count == 2) {
return nums[i-1];
}
}
return nums[length-1];
}

06 小结

算法专题目前已连续日更超过两个月,算法题文章89+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode算法题-Third Maximum Number(Java实现-四种解法)的更多相关文章

  1. LeetCode算法题-Move Zeroes(Java实现-三种解法)

    这是悦乐书的第201次更新,第211篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第67题(顺位题号是283).给定一个数组nums,写一个函数将所有0移动到它的末尾,同 ...

  2. LeetCode算法题-Add Digits(Java实现-3种解法)

    这是悦乐书的第199次更新,第207篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第63题(顺位题号是258).给定非负整数num,重复添加其所有数字,直到结果只有一位数 ...

  3. LeetCode算法题-Reach a Number(Java实现)

    这是悦乐书的第310次更新,第331篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第179题(顺位题号是754).你站在无限数字线的0号位置.在目的地有个target.在 ...

  4. LeetCode算法题-Convert a Number to Hexadecimal(Java实现)

    这是悦乐书的第219次更新,第231篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第86题(顺位题号是405).给定一个整数,写一个算法将其转换为十六进制.对于负整数,使 ...

  5. LeetCode算法题-Missing Number(Java实现-四种解法)

    这是悦乐书的第200次更新,第209篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第65题(顺位题号是268).给定一个包含n个不同数字的数组,取自0,1,2,...,n ...

  6. LeetCode算法题-Ugly Number(Java实现-四种解法)

    这是悦乐书的第199次更新,第208篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第64题(顺位题号是263).编写一个程序来检查给定的数字是否是一个丑陋的数字.丑陋的数 ...

  7. LeetCode算法题-Rotate String(Java实现)

    这是悦乐书的第317次更新,第338篇原创 在开始今天的算法题前,说几句,今天是世界读书日,推荐两本书给大家,<终身成长>和<禅与摩托车维修艺术>,值得好好阅读和反复阅读. 0 ...

  8. LeetCode算法题-Rotated Digits(Java实现)

    这是悦乐书的第316次更新,第337篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第185题(顺位题号是788).如果一个数字经过180度旋转后,变成了一个与原数字不同的 ...

  9. LeetCode算法题-Minimum Distance Between BST Nodes(Java实现-四种解法)

    这是悦乐书的第314次更新,第335篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第183题(顺位题号是783).给定具有根节点值的二叉搜索树(BST),返回树中任何两个 ...

随机推荐

  1. 翻译:如何向MariaDB中快速插入数据(已提交到MariaDB官方手册)

    本文为mariadb官方手册:How to Quickly Insert Data Into MariaDB的译文. 原文:https://mariadb.com/kb/en/how-to-quick ...

  2. c#金额转换成中文大写金额

    2018-08-24 转别人 c#金额转换成中文大写金额 /// <summary> /// 金额转换成中文大写金额 /// </summary> /// <param ...

  3. ASP.NET MVC 学习笔记-5.Controller与View的数据传递

    ViewData属性 ViewData属性是System.Web.Mvc.ControllerBase中的一个属性,它相当于一个数据字典.Controller中向该字典写入数据,ViewData[“K ...

  4. collect_list/collect_set(列转行)

    Hive中collect相关的函数有collect_list和collect_set. 它们都是将分组中的某列转为一个数组返回,不同的是collect_list不去重而collect_set去重. 做 ...

  5. SSM 设置静态资源处理

    使用weblogic的虚拟路径virtual-directory-mapping 在页面上展示文件服务器上的图片 <weblogic-web-app> ......省略其他部分 <c ...

  6. 在Java中进行序列化和反序列化

    对象序列化的目标是将对象保存在磁盘中,或者允许在网络中直接传输对象. 对象序列化允许把内存中的Java对象转换成平台无关的二进制流,从而允许把这种二进制流持久保存在磁盘上或者通过网络将这种二进制流传输 ...

  7. 8.异常_EJ

    第57条: 只针对异常情况才使用异常 异常是为了在异常情况下使用而设计的,不要将它们用于普通的控制流,也不要编写迫使它们这么做的API. 第58条: 对可恢复的情况使用受检异常,对编程错误使用运行时异 ...

  8. 你所不知道的JSON.stringify

    译者按: 老司机们,你知道JSON.stringify还有第二个和第三个可选参数吗?它们是什么呢? 原文: What you didn’t know about JSON.Stringify 译者: ...

  9. hihoCoder编程练习赛67

    题目1 : 序列 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 给定两个正整数 n, P,求满足以下两个条件的长度为 n 的序列 ai 个数: 1. 1 ≤ ai ≤ ...

  10. vue-i18n和ElementUI国际化使用

    在main.js同级建i18n文件夹,并里面建i18n.js.langs文件夹,langs文件夹下建en.js.cn.js目录如下: 展示效果地址: http://www.cenweixin.cn/w ...