首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >每日三题-盛最多水的容器、三数之和、移动零

每日三题-盛最多水的容器、三数之和、移动零

作者头像
才疏学浅的木子
发布2022-11-20 16:46:43
发布2022-11-20 16:46:43
24300
代码可运行
举报
文章被收录于专栏:CSDN文章CSDN文章
运行总次数:0
代码可运行

👨‍💻个人主页: 才疏学浅的木子 🙇‍♂️ 本人也在学习阶段如若发现问题,请告知非常感谢 🙇‍♂️ 📒 本文来自专栏: 算法 🌈 算法类型Hot100题 🌈 ❤️ 支持我:👍点赞 🌹收藏 🤟关注

每日三题

盛最多水的容器

解法一

双指针 left指向左边,right指向右边 如果num[left] <= num[right] 那么left++反之righht– 因为盛水靠矮的一方

代码语言:javascript
代码运行次数:0
运行
复制
class Solution {
    public int maxArea(int[] height) {
        int len = height.length;
        if(len <= 1) return 0;
        int left = 0;
        int right = len-1;
        int res = 0;
        while(left < right){
            res = Math.max(res,Math.min(height[left],height[right])*(right-left));
            if(height[left] <= height[right]) left++;
            else if(height[left] > height[right]) right--;
        }
        return res;
    }
}

三数之和

解法一

双指针 先进行排序,然后遍历当前num[i] + num[left] +num[right] 与 0 的大小 如果大于0所以right–; 如果小于0所以left++

代码语言:javascript
代码运行次数:0
运行
复制
class Solution {
    public List<List<Integer>> threeSum(int[] nums) {
        int len = nums.length;
        List<List<Integer>> list = new ArrayList<>();
        if(len < 3) return list;
        Arrays.sort(nums);
        for(int i = 0;i < len;i++){
            if(i > 0 && nums[i-1] == nums[i]) continue;
            int left = i + 1;
            int right = len-1;
            while(left < right){
                if(nums[i] + nums[left] + nums[right] == 0){
                    // System.out.println(i+"=="+left+"=="+right);
                    List<Integer> t = new ArrayList<>();
                    t.add(nums[i]);
                    t.add(nums[left]);
                    t.add(nums[right]);
                    list.add(t);
                    while(left < right && nums[left+1] == nums[left]) left++;
                    while(left < right && nums[right-1] == nums[right]) right--;
                    left++;
                    right--;
                }else if(nums[i] + nums[left] + nums[right] > 0){
                    right--;
                }else left ++;
            }
        }
        return list;
    }
}

移动零

代码语言:javascript
代码运行次数:0
运行
复制
class Solution {
    public void moveZeroes(int[] nums) {
        int len = nums.length;
        if(len == 0) return;
        int right = 0;
        for(int i = 0;i < len;i++){
            if(nums[i] != 0){
                nums[right++] = nums[i];
            }
        }
        for(int i = right;i < len;i++){
            nums[i] = 0;
        }
        return;
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-11-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 每日三题
  • 盛最多水的容器
  • 三数之和
  • 移动零
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档