力扣打卡——盛最多水的容器、三数之和

目录

[11. 盛最多水的容器 - 力扣(LeetCode)](#11. 盛最多水的容器 - 力扣(LeetCode))

[15. 三数之和 - 力扣(LeetCode)](#15. 三数之和 - 力扣(LeetCode))


11. 盛最多水的容器 - 力扣(LeetCode)

思路:刚以看到这个问题的时候,直接用两层循环,这种解法是把所有的情况都算出来,这种时间的复杂度是n方,但是看到题解的思路,自己大致明白双指针思路,一个指针直到开始,一个结尾直到结尾,比较两个指针的高度,如果那个高度比较低,指针向前或者向后,大的指针不动,

复制代码
class Solution {
    public int maxArea(int[] height) {
        //数组为空
        if(height==null||height.length==0){
            return 0;
        }
        
        int i=0,j=height.length-1;
        int result=0;
        //使用双指针进行解决
        while(i<j){
            result=Math.max(result,(j-i)*Math.min(height[i],height[j]));
            if(height[i]<height[j]){
                i++;
            }else{
                j--;
            }
        }
        return result;
    }
}

15. 三数之和 - 力扣(LeetCode)

大体思路:

1.对数组进行排序,方便取数和去重,

  1. i的起始为0,定一个下标left 定义在i+1的位置上,定义下标right 在数组结尾的位置上。

a 为 nums[i] b为nums[left] c为nums[right]

找到a,进行去重

  1. 接下来如何移动left 和right呢, 如果nums[i] + nums[left] + nums[right] > 0 就说明 此时三数之和大了,因为数组是排序后了,所以right下标就应该向左移动,这样才能让三数之和小一些。

如果 nums[i] + nums[left] + nums[right] < 0 说明 此时 三数之和小了,left 就向右移动,才能让三数之和大一些,直到left与right相遇为止。

找到left 和right后,进行去重

主要的就是去重:

//a的去重

if(i>0&&nums[i]==nums[i-1]){

continue;

}

例子:{-1,-1,-2,3}

这么写就是当前使用 nums[i],我们判断前一位是不是一样的元素,在看{-1,-1,-2,3}这组数据,当遍历到 第二个 -1 的时候,只要前一位没有-1,那么 {-1, -2,3} 这组数据一样可以收录到 结果集里。若是nums[i]==nums[i+1]的话,遍历到 第一个 -1 的时候 ,结果{-1,-2,3} 这组数据会直接跳过**,不会进入结果集**

//right去重

while(right>left &&nums[right]==nums[right-1]) right--;

//left 去重

while(right>left &&nums[left]==nums[left+1]) left++;

{0,-1,-1,-1,-1,1,1,1,1}

例子中有大量重复的-1和1 ,去重后结果{0,-1,1}

复制代码
class Solution {
    public List<List<Integer>> threeSum(int[] nums) {
        List<List<Integer>> result=new ArrayList<>();
        //进行排序
        Arrays.sort(nums);
        int length=nums.length;
        
        for(int i=0;i<length;i++){
           if(nums[i]>0){
            return result;
           }
           //a去重
           if(i>0&&nums[i]==nums[i-1]){
              continue;
           }
           int left=i+1;
           int right=length-1;
           //进行双指针
           while(left<right){
              if(nums[i]+nums[left]+nums[right]>0){
                right--;
              }else if(nums[i]+nums[left]+nums[right]<0){
                left++;
              }else{
                //加入结果集
                result.add(Arrays.asList(nums[i],nums[left],nums[right]));
                //left去重
                while(left<right && nums[left]==nums[left+1]) left++;
                //right去重
                while(left<right && nums[right]==nums[right-1]) right--;
                //进入到真正的取数
                left++;
                right--;
              }
           }
        }
        return result;
    }
}
相关推荐
Barkamin2 小时前
快速排序非递归实现
java·算法·排序算法
gihigo19982 小时前
距离角度解耦法的MIMO-OFDM雷达波束形成及优化MATLAB实现
开发语言·算法·matlab
WolfGang0073212 小时前
代码随想录算法训练营 Day12 | 二叉树 part02
算法·深度优先
2401_853576502 小时前
代码自动生成框架
开发语言·c++·算法
逆境不可逃2 小时前
【从零入门23种设计模式23】行为型之模板模式
java·开发语言·算法·设计模式·职场和发展·模板模式
ZPC82102 小时前
PPO 在ROS2 中训练与推理
人工智能·算法·机器人
IronMurphy2 小时前
【算法二十五】105. 从前序与中序遍历序列构造二叉树 236. 二叉树的最近公共祖先
java·数据结构·算法
2401_853576502 小时前
C++中的组合模式变体
开发语言·c++·算法
像污秽一样2 小时前
算法设计与分析-习题8.2
数据结构·算法·排序算法·dfs·化简