题解 | #盛水最多的容器#

盛水最多的容器

https://www.nowcoder.com/practice/3d8d6a8e516e4633a2244d2934e5aa47

int maxArea(int* height, int heightLen ) {
    // write code here
    int maxRet = 0, temp;
    for(int i=0; i<heightLen; i++){
        for(int j=heightLen-1; j>i; j--){
            //剪枝,左边固定的高度,乘左右的宽度小于最大值maxRet,此时直接跳过该轮左边的循环
            //因为即使右边的高度大于左边,也是以最低边为上限(即左边)。后面j不断缩小,更不可能得出更大的容器
            if(height[i] * (j-i) < maxRet)          
                break;                              
            temp = (height[j] <= height[i] ? height[j] : height[i])*(j-i);
            maxRet = maxRet > temp ? maxRet : temp;
        }
    }
    return maxRet;
}

全部评论

相关推荐

牛客383479252号:9,2学生暑期实习失利开始投小厂,给这群人整自信了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务