我是靠谱客的博主 甜美百褶裙,这篇文章主要介绍第三大的数,现在分享给大家,希望可以做个参考。

给定一个非空数组,返回此数组中第三大的数。如果不存在,则返回数组中最大的数。要求算法时间复杂度必须是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
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解体:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
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; } }

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

最后

以上就是甜美百褶裙最近收集整理的关于第三大的数的全部内容,更多相关第三大内容请搜索靠谱客的其他文章。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部