我是靠谱客的博主 甜美百褶裙,最近开发中收集的这篇文章主要介绍第三大的数,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

给定一个非空数组,返回此数组中第三大的数。如果不存在,则返回数组中最大的数。要求算法时间复杂度必须是O(n)。

示例 1:

输入: [3, 2, 1]

输出: 1

解释: 第三大的数是 1.
示例 2:

输入: [1, 2]

输出: 2

解释: 第三大的数不存在, 所以返回最大的数 2 .
示例 3:

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

输出: 1

解释: 注意,要求返回第三大的数,是指第三大且唯一出现的数。
存在两个值为2的数,它们都排第二

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/third-maximum-number
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解体:

class Solution {
public int thirdMax(int[] nums) {
int a =nums.length;
int max=nums[0];
int temp1=nums[0];
int temp2=nums[0];
int temp3=nums[0];
boolean fg=false;
if (a==3){
//you chongfu shuzi
for(int i=0;i<a-1;i++){
if(nums[i]==nums[i+1])
fg=true;
}
if(fg){
for (int i=0;i<a;i++){
if (nums[i]>=max)
max=nums[i];
}
}
else{
for (int i=0;i<a;i++){
if (nums[i]<=max)
max=nums[i];
}
}
//meiyou chongfu shuzi
return max;
}
if (a==2)
return nums[1]>=nums[0]?nums[1]:nums[0];
if (a==1)
return nums[0];
else{
for (int i=0;i<nums.length;i++){
if (nums[i]>=temp1){
temp1=nums[i];
}
}
boolean d=false;
for (int i=0;i<nums.length;i++){
if (nums[i]<temp1){
if (!d){
d=true;
temp2=nums[i];
}
else if(nums[i]>=temp2){
temp2=nums[i];
}
}
}
boolean dd=false;
for (int i=0;i<nums.length;i++){
if (nums[i]<temp2){
if (!dd){
dd=true;
temp3=nums[i];
}
else if (nums[i]>=temp3)
temp3=nums[i];
}
}
}
if(temp3==nums[0])
temp3=temp1;
return temp3;
}
}

简单也不会系列,就是这了。心累,简单的题,代码这么多多多。。。

最后

以上就是甜美百褶裙为你收集整理的第三大的数的全部内容,希望文章能够帮你解决第三大的数所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部