关闭

Leetcode-414. Third Maximum Number

163人阅读 评论(0) 收藏 举报
分类:

题目

Given a non-empty array of integers, return the third maximum number in this array. If it does not exist, return the maximum number. The time complexity must be in O(n).

Example 1:
Input: [3, 2, 1]

Output: 1

Explanation: The third maximum is 1.
Example 2:
Input: [1, 2]

Output: 2

Explanation: The third maximum does not exist, so the maximum (2) is returned instead.
Example 3:
Input: [2, 2, 3, 1]

Output: 1

Explanation: Note that the third maximum here means the third maximum distinct number.
Both numbers with value 2 are both considered as second maximum.

解答

这一题看着简单,其实不是那么容易AC的。主要是需要对一些特殊的输入进行特殊处理。
注意:[2,1,1]这种情况是不存在第三大的,返回2。

用三个变量first,second,third来表示第一大,第二大,第三大。
用count来表示这三个更新次数。如果更新次数大于等于3,直接返回third。
如果小于3,那就是返回最大值。
但是有一个特殊的例子:
[2,1,-2147483648],这个在判断第三个时是不更新的,所以额外对其进行计数,用bottom来计数,在最后的判断中就用count+bottom来判断。
AC代码:9ms

class Solution {
public:
    int thirdMax(vector<int>& nums) {
        #define INT_MIN (-2147483647-1)
        int max_3[3];
        if(nums.size()==1) return nums[0];
        else if(nums.size()==2) return nums[1]>nums[0]?nums[1]:nums[0];
        else
        {
            int first=INT_MIN,second=INT_MIN,third=INT_MIN;
            bool flag1=0,flag2=0,flag3=0;//是否顶替掉初值
            int count=0;
            int bottom=0;

            //缺少对三个一样的进行判断
            for(int i=0;i<nums.size();i++)
            {
                if(nums[i]==-2147483648) bottom=1;//有一个不需要更新
                if(nums[i]==first||nums[i]==second||nums[i]==third)//如果有相同的数,至少有一个是更新的
                    continue;
                if(nums[i]>first)
                {
                    third=second;
                    second=first;
                    first=nums[i];
                    count++;
                }
                else if(nums[i]>second)
                {
                    third=second;
                    second=nums[i];
                    count++;
                }
                else if(nums[i]>third)
                {
                    third=nums[i];
                    count++;
                }
            }
            if(count+bottom>=3)// 
                return third;//三个都更新了
            else 
                return first;//两个更新,一个更新或者都没更新,没达到要求,返回第一个值

        }

    }
};
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

Windows下用Nginx+Tomcat配置集群负载均衡

Nginx是一款轻量级的web服务器/反向代理服务器,更详细的释义自己百度了。目前国内像新浪、网易等都在使用它。
  • a443453087
  • a443453087
  • 2015-01-27 15:01
  • 9450

使用Bosh在OpenStack上部署CloudFoundry碰到的问题

部署Micro Bosh碰到的问题 一、Micro Bosh虚拟机上执行micro bosh部署命令时出错: bosh micro deploy /var/vcap/stemcells/micro-...
  • tiger435
  • tiger435
  • 2013-04-23 17:45
  • 3831

Redis介绍以及安装(Linux)

redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统。和Memcached类似,但很大程度补偿了memcached的不足,它支持存储的value类型相对更多,包括strin...
  • zhaifengmin
  • zhaifengmin
  • 2015-06-10 22:03
  • 1420

redis 的图标挺有意思的

redis 的使用 1.安装redis官网的步骤安装redis (http://redis.io/download) $ wget http://download.redis.io/relea...
  • menxu_work
  • menxu_work
  • 2014-09-16 10:12
  • 5641

npoi workbook 的 cellstyle 创建不能超过4000的解决方法

npoi workbook 的 cellstyle 创建不能超过4000的解决方法 The maximum number of cell styles was exceeded. You can de...
  • sharpnessdotnet
  • sharpnessdotnet
  • 2015-02-02 14:00
  • 11731

记录FFmpeg的help文档中命令行参数。

Synopsis: ffmpeg [global_options] {[input_file_options] -i input_file}... {[output_file_options]outp...
  • liuer2004_82
  • liuer2004_82
  • 2016-02-08 17:18
  • 2009

Hive中reduce个数设定

Hive中reduce个数设定原理解析
  • u014388509
  • u014388509
  • 2014-06-24 14:46
  • 5929

iOS开发 适配iOS10以及Xcode8

现在在苹果的官网上,我们已经可以下载到Xcode8的GM版本了,加上9.14日凌晨,苹果就要正式推出iOS10系统的推送了,在此之际,iOS10的适配已经迫在眉睫啦,不知道Xcode8 beat版本,...
  • QearlYu
  • QearlYu
  • 2016-09-22 17:16
  • 4764

libsvm 代码分析

void Solve(int l, QMatrix Q, double[] p_, byte[] y_,   double[] alpha_, double Cp, double Cn, double...
  • keith0812
  • keith0812
  • 2013-12-03 13:34
  • 1289

Android 混淆代码的时候出现问题

今天导出APK之前,对代码进行混淆处理,结果出现了以下问题。 ——————————————————————————————  Proguard returned with error code 1...
  • eieihihi
  • eieihihi
  • 2014-12-10 11:05
  • 4513
    个人资料
    • 访问:91453次
    • 积分:2204
    • 等级:
    • 排名:第19785名
    • 原创:150篇
    • 转载:22篇
    • 译文:0篇
    • 评论:24条
    最新评论