亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++實現LeetCode(11.裝最多水的容器)

 更新時間:2021年07月12日 11:11:49   作者:Grandyang  
這篇文章主要介紹了C++實現LeetCode(11.裝最多水的容器),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下

[LeetCode] 11. Container With Most Water 裝最多水的容器

Given n non-negative integers a1a2, ..., an , where each represents a point at coordinate (iai). n vertical lines are drawn such that the two endpoints of line i is at (iai) and (i, 0). Find two lines, which together with x-axis forms a container, such that the container contains the most water.

Note: You may not slant the container and nis at least 2.

The above vertical lines are represented by array [1,8,6,2,5,4,8,3,7]. In this case, the max area of water (blue section) the container can contain is 49.

Example:

Input: [1,8,6,2,5,4,8,3,7]
Output: 49

這道求裝最多水的容器的題和那道 Trapping Rain Water 很類似,但又有些不同,那道題讓求整個能收集雨水的量,這道只是讓求最大的一個的裝水量,而且還有一點不同的是,那道題容器邊緣不能算在里面,而這道題卻可以算,相比較來說還是這道題容易一些,這里需要定義i和j兩個指針分別指向數組的左右兩端,然后兩個指針向中間搜索,每移動一次算一個值和結果比較取較大的,容器裝水量的算法是找出左右兩個邊緣中較小的那個乘以兩邊緣的距離,代碼如下:

C++ 解法一:

class Solution {
public:
    int maxArea(vector<int>& height) {
        int res = 0, i = 0, j = height.size() - 1;
        while (i < j) {
            res = max(res, min(height[i], height[j]) * (j - i));
            height[i] < height[j] ? ++i : --j;
        }
        return res;
    }
};

Java 解法一:

public class Solution {
    public int maxArea(int[] height) {
        int res = 0, i = 0, j = height.length - 1;
        while (i < j) {
            res = Math.max(res, Math.min(height[i], height[j]) * (j - i));
            if (height[i] < height[j]) ++i;
            else --j;
        }
        return res;
    }
}

這里需要注意的是,由于 Java 中的三元運算符 A?B:C 必須須要有返回值,所以只能用 if..else.. 來替換,不知道 Java 對于三元運算符這么嚴格的限制的原因是什么。

下面這種方法是對上面的方法進行了小幅度的優(yōu)化,對于相同的高度們直接移動i和j就行了,不再進行計算容量了,參見代碼如下:

C++ 解法二:

class Solution {
public:
    int maxArea(vector<int>& height) {
        int res = 0, i = 0, j = height.size() - 1;
        while (i < j) {
            int h = min(height[i], height[j]);
            res = max(res, h * (j - i));
            while (i < j && h == height[i]) ++i;
            while (i < j && h == height[j]) --j;
        }
        return res;
    }
};

Java 解法二:

public class Solution {
    public int maxArea(int[] height) {
        int res = 0, i = 0, j = height.length - 1;
        while (i < j) {
            int h = Math.min(height[i], height[j]);
            res = Math.max(res, h * (j - i));
            while (i < j && h == height[i]) ++i;
            while (i < j && h == height[j]) --j;
        }
        return res;
    }
}

到此這篇關于C++實現LeetCode(11.裝最多水的容器)的文章就介紹到這了,更多相關C++實現裝最多水的容器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C++實現經典24點紙牌益智游戲

    C++實現經典24點紙牌益智游戲

    這篇文章主要介紹了C++實現經典24點紙牌益智游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • C++求兩數之和并返回下標詳解

    C++求兩數之和并返回下標詳解

    這篇文章主要介紹了C++求兩數之和并返回下標題目的代碼詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-08-08
  • C++賦值函數+移動賦值函數+移動構造函數詳解

    C++賦值函數+移動賦值函數+移動構造函數詳解

    這篇文章主要介紹了C++賦值函數+移動賦值函數+移動構造函數詳解,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • 實例代碼分析c++動態(tài)分配

    實例代碼分析c++動態(tài)分配

    這篇文章主要介紹了c++動態(tài)分配的的相關資料,文中代碼簡單易懂,方便大家更好的學習參考,感興趣的朋友可以了解下
    2020-06-06
  • C/C++語言宏定義使用實例詳解

    C/C++語言宏定義使用實例詳解

    這篇文章主要介紹了 C/C++語言宏定義使用實例詳解的相關資料,需要的朋友可以參考下
    2017-06-06
  • 解析C++哈夫曼樹編碼和譯碼的實現

    解析C++哈夫曼樹編碼和譯碼的實現

    本篇文章主要介紹了C++哈夫曼樹編碼和譯碼的實現,詳細的講訴了哈夫曼樹編碼的原理,有需要的同學可以了解一下。
    2016-11-11
  • C語言中char*和char[]用法區(qū)別分析

    C語言中char*和char[]用法區(qū)別分析

    這篇文章主要介紹了C語言中char*和char[]用法區(qū)別,包括使用過程中的誤區(qū)及注意點分析,需要的朋友可以參考下
    2014-09-09
  • C++的繼承特性你了解嗎

    C++的繼承特性你了解嗎

    這篇文章主要為大家詳細介紹了C++的繼承特性,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • C++編程產生指定范圍內的隨機數

    C++編程產生指定范圍內的隨機數

    這篇文章主要為大家詳細介紹了C++編程產生指定范圍內的隨機數,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • JS調用C++函數拋出異常及捕捉異常詳解

    JS調用C++函數拋出異常及捕捉異常詳解

    這篇文章主要介紹了js調用C++函數的方法示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-08-08

最新評論