前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每日三题-盛最多水的容器、三数之和、移动零

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

作者头像
才疏学浅的木子
发布2022-11-20 16:46:43
1790
发布2022-11-20 16:46:43
举报
文章被收录于专栏:CSDN文章CSDN文章

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

每日三题

盛最多水的容器

在这里插入图片描述
在这里插入图片描述

解法一

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

代码语言:javascript
复制
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
复制
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
复制
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 条评论
热度
最新
推荐阅读
目录
  • 每日三题
  • 盛最多水的容器
  • 三数之和
  • 移动零
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com