双指针问题(Java编写)

日升时奋斗,日落时自省 

目录

一、移动零

二、盛水最多的容器

三、快乐数

四、复写零

五、三数之和

六、有效三角形的个数

七、四数之和


一、移动零

题目来源:. - 力扣(LeetCode)

题目主要内容就是将数组中所有的零移动到最左边

使用快慢指针方法进行处理

代码: 

    public void moveZeroes(int[] nums) {
        for(int cur=0;dest=-1;cur<nums.length;cur++){
            if(nums[cur]!=0){
                //在判定当前值不等于 0 dest就可以进行加加
                dest++;
                //进行值的替换
                int tmp = nums[cur];
                nums[cur]=nums[dest];
                nums[dest]=tmp;
            }
        }
    }

二、盛水最多的容器

题目来源:. - 力扣(LeetCode)

题目主要内容横坐标的差值为长度,纵坐标的两个最小值为宽度,就散长方形的面积最大

代码:

    public int maxArea(int[] height) {
        int left = 0 , right = height.length-1 ,ret=0;
        while(left<right){
            //计算面积
            int v = Math.min(height[left],height[right])*(right-left);
            //取最大值
            ret= Math.max(ret,v);
            //进行位置调节
            if(height[left]<height[right]){
                left++;
            }else{
                right--;
            }
        }
        return ret;
    }

三、快乐数

题目来源:. - 力扣(LeetCode)

题目主要内容重复每个位的数进行平方相加==0为快乐数

代码:

    //计算数值个位的平方和
    public int bigSum(int t){
        int sum=0;
        while(t>0){
            int tmp= t%10;
            sum+=tmp*tmp;
            t/=10;
        }
        return sum;
    }
    public boolean isHappy(int n) {
        //第一个和第二个不同
        int slow = n, fast = bigSum(n);
        while(slow!=fast){
            //走一步
            slow=bigSum(slow);
            //快指针走两步
            fast=bigSum(bigSum(fast));
        }
        return slow==1;
    }

四、复写零

题目来源:. - 力扣(LeetCode)

题目主要内容每次遇到0就复写一次,后面数值向后移动,末尾数值因为数组大小不变就消失了

上图没有画完,一次类推可以得出结果

注:那当前假设的位置怎么找,这里再配一张图解释

边界情况:

 

代码:

    public void duplicateZeros(int[] nums) {
        int cur= 0 , dest = -1 , n=nums.length;
        //先去找假设值
        while(cur<n){
            if(nums[cur]!=0){
                dest++;
            }else{
                dest+=2;
            }        
            if(dest>=n-1)break;
            cur++;
        }
        //越界判断
        if(dest==n){
            nums[n-1]=0;
            cur--;
            dest-=2;
        }
        //复写零
        while(cur>0){
            if(nums[cur]!=0){
                nums[dest--]=nums[cur--];
            }else{
                nums[dest--]=0;
                nums[dest--]=0;
                cur--;
            }
        }
    }

五、三数之和

题目来源:. - 力扣(LeetCode)

题目主要内容数组中任意三个数和等于target记录下来即可

暴力解法:三个for循环进行遍历就可以解决,当然时间复杂度太高

题解思路:

因为给的数组是无序的,要是使用双指针的话不确定因素太多(就是控制不了数值总和的大小)

首先给数组排个序Java调用库函数就可以排序了

代码:

    public List<List<Integer>> threeSum(int[] nums) {
        List<List<Integer>> ret=new ArrayList<>();
        //进行排序
        Arrays.sort(nums);
        int n=nums.length;
        for(int i=0;i<n;){
            if(nums[i]>0)break;
            int left = i + 1;
            int right = n-1;
            
            while(left<right){
                //求和
                int sum = nums[i]+nums[left]+nums[right];
                //小于说明left值太小 向后取更大的
                if(sum<0){
                    left++;
                //大于说明right值太大 向前取更小的
                }else if(sum>0){
                    right--;
                }else{
                    //等于就添加进集合中  同时跳过两个位置
                    ret.add(new ArrayList<>(Arrays.asList(nums[i],nums[left],nums[right])));
                    right--;
                    left++;
                    //左去重 
                    while(left<right&&nums[left]==nums[left-1]){
                        left++;
                    }
                    //右去重
                    while(left<right&&nums[right]==nums[right+1]){
                        right--;
                    }
                }
            }
            i++;
            //第一个数去重
            while(i<n&&nums[i]==nums[i-1]){
                i++;
            }
        }
        return ret;
    }

六、有效三角形的个数

题目来源:. - 力扣(LeetCode)

题目主要内容计算有效三角形的个数

三角形满足两小边之和大于第三边

如何知道那两个边是小的 ,这里就可以进行排序使用双指针解决问题

最大边就是右边的值

代码:

    public int triangleNumber(int[] nums) {
        if(nums.length<3){
            return 0;
        }
        Arrays.sort(nums);
        int ret=0;
        for(int i=nums.length-1;i>=2;i--){
            int left = 0, right =i-1;
            int maxnum=nums[i];
            //双指针移动
            while(left<right){
                if(nums[left]+nums[right]>maxnum){
                        //可以跳过当前值
                        ret+=right-left;
                        right--;
                    }else{
                        //如果针对以上的不满足的 说明值是太小的,left进行++
                        left++;
                    }
                }
            }
        return ret;
    }

七、四数之和

题目来源:. - 力扣(LeetCode)

题目主要内容类似与三数之和,多嵌套一层for循环进行计算,就是固定两个数字不变其他的两个数字称为双指针进行移动

代码:

    public List<List<Integer>> fourSum(int[] nums, int target) {
        if(nums.length<4){
           return new ArrayList<>();
        }
        List<List<Integer>> ret=new ArrayList<>();
        int n=nums.length;
        //进行排序 为了 双指针 在计算的时候可以决定总和的大小
        Arrays.sort(nums);
        for(int i=0;i<n;){
            for(int j=i+1;j<n;){
                int left = j+1;
                int right = n-1;
                while(left<right){
                    if(nums[i]+nums[j]+nums[left]+nums[right]<target){
                        left++;
                    }else if(nums[i]+nums[j]+nums[left]+nums[right]>target){
                        right--;
                    }else{
                        ret.add(new ArrayList<>(Arrays.asList(nums[i],nums[j],nums[left],nums[right])));
                        left++;
                        right--;
                        //双指针去重
                        while(left<right&&nums[left]==nums[left-1]){
                            left++;
                        }
                        while(left<right&&nums[right]==nums[right+1]){
                            right--;
                        }
                    }
                }
                //第二个数字的去重
                j++;
                while(j<n&&nums[j]==nums[j-1]){
                    j++;
                }
            }
            //第一个数字的去重
            i++;
            while(i<n&&nums[i]==nums[i-1]){
                i++;
            }
        }
        return ret;
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/418044.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

FPGA高端项目:FPGA基于GS2971的SDI视频接收+图像缩放,提供3套工程源码和技术支持

目录 1、前言免责声明 2、相关方案推荐本博已有的 SDI 编解码方案本方案的SDI接收转HDMI输出应用本方案的SDI纯verilog图像缩放视频拼接应用本方案的SDI HLS图像缩放视频拼接应用本方案的SDI视频编码动态字符叠加输出应用本方案的SDI视频编码多路视频融合视频叠加应用FPGA的SDI…

Redis 群集部署

部署配置实验 实验环境 虚拟机 6台 centos7.9 网卡NAT模式 数量 1 组件包Redis安装包 设备 IP 备注 Centos01 192.168.9.31 Node1 Centos02 192.168.9.32 Node2 Centos03 192.168.9.33 Node3 Centos04 192.168.9.34 Node4 Centos05 192.168.9.35 Node5 C…

windows下安装npm

windows下安装了多个node.js如何切换npm。 下载nvm 下载nvm地址&#xff1a;https://github.com/coreybutler/nvm-windows/releases 安装nvm 这个是nodejs的安装位置&#xff0c;如果没有nodejs文件夹就新建一个(后来发现他会自动生成一个快捷方式) 设置setting.txt 打开安装…

新一轮寒潮来袭!浙江电网首次应用运载无人机进行输电线路除冰作业

近期&#xff0c;受低温雨雪冰冻天气的影响&#xff0c;浙江多地迎来罕见冻雨、冰雹天气&#xff0c;高海拔山区气温持续维持零摄氏度以下&#xff0c;部分输配电线路出现覆冰现象&#xff0c;部分地区电力供应受到影响。 为保障线路安全稳定运行&#xff0c;国网浙江供电公司于…

2019年上半年教师资格证考试《教育知识与能力》(中学)题

2.苏联教育家赞可夫倡导的是&#xff08;C &#xff09;。 A发现学习理论 B教学过程最优化理论 C教学与发展理论 D范例教学理论 9.我国《基础教育课程改革纲要&#xff08;试行&#xff09;》规定&#xff0c;在课程设置上&#xff0c;高中阶段&#xff08;B &#xff09;。…

Java学习笔记------接口

接口 接口就是一种规则,对行为的抽象 定义和使用接口 用关键字interface来定义&#xff0c;public interface 接口名{} 接口不能实例化 接口和类之间是实现关系&#xff0c;通过impls关键字表示 public class 类名 implements 接口名{} 接口的子类&#xff08;实现类&am…

数据可视化基础与应用-02-基于powerbi实现医院数据集的指标体系的仪表盘制作

总结 本系列是数据可视化基础与应用的第02篇&#xff0c;主要介绍基于powerbi实现医院数据集的指标体系的仪表盘制作。 数据集描述 医生数据集doctor 医生编号是唯一的&#xff0c;名称会存在重复 医疗项目数据projects 病例编号是唯一的&#xff0c;注意这个日期编号不是真…

HarmonyOS—开发云数据库

您可以在云侧工程下开发云数据库资源&#xff0c;包括创建对象类型、在对象类型中添加数据条目、部署云数据库。 创建对象类型 对象类型&#xff08;即ObjectType&#xff09;用于定义存储对象的集合&#xff0c;不同的对象类型对应的不同数据结构。每创建一个对象类型&#…

PackagingTool_x64_v2.0.1.0图片转档打包二进制文件合并字库生成图片软件介绍

继去年12月份发布的打包软件PackagingTool v1.4.0.2之后&#xff0c;今年再度投入精力&#xff0c;完善了软件功能&#xff0c;同时开发了几个更加实用的工具&#xff0c;可助力UI界面的设计开发。当前最新版本为PackagingTool_x64_v2.0.1.0&#xff0c;该版本主界面如下&#…

TCP/UDP模型:2024/2/29

作业1&#xff1a;TCP模型 服务器端&#xff1a; #include <myhead.h> #define SER_IP "192.168.199.129" #define SER_PORT 8899int main(int argc, const char *argv[]) {//1.创建用于连接的套接字文件int sfdsocket(AF_INET,SOCK_STREAM,0);if(sfd-1){per…

5 分钟配置好 Electron 应用的图标

最近在开发博客本地客户端 HexoPress&#xff0c;应用做好后&#xff0c;需要打包&#xff0c;如果不希望打包出来 App 的图标用的是 Electron 默认的星球环绕的图标&#xff0c;那么需要自己制作图标。 制作图标 首先&#xff0c;你需要给各种操作系统制作一个满足要求的图标…

hcip--VLAN实验

一&#xff1a;实验要求 二&#xff1a; 实验分析 1.pc1和pc3在同一个vlan&#xff08;vlan2&#xff09;&#xff0c;因为是access接口模式&#xff0c;那么需和pc2/4/5/6不在同一个网 段&#xff0c;则是做路由器的子接口。 2. pc2/4/5/6在同一个网段&#xff0c;且需要实…

Java+SpringBoot,打造社区疫情信息新生态

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…

FPGA-DDS原理及实现

DDS(Direct Digital Synthesizer)即数字合成器,是一种新型的频率合成技术,具有相对带宽大,频率转换时间短、分辨率高和相位连续性好等优点。较容易实现频率、相位以及幅度的数控调制,广泛应用于通信领域。 相位累加器是由N位加法器与N位寄存器构成,每个时钟周期的上升沿,加法器…

公司电脑ip所在地查询方法参考

公司局域网 可以看到这种方法查不出来 直接百度 直接被智能云识别了出来 询问gpt的方法 获得ipv6 curl ifconfig.me 但是ipv6好像对我们并没有多大帮助

自动化构建平台(三)Linux搭建私有的docker镜像库之Harbor的安装和使用详解

文章目录 前言一、Harbor的安装第一步&#xff1a;安装docker第二步&#xff1a;安装docker-compose第三步&#xff1a;安装Harbor 二、Harbor登录三、Harbor项目管理第一步&#xff1a;创建项目第二步&#xff1a;推送镜像 四、Harbor权限控制五、Harbor自动清理多余的镜像手动…

广汽埃安工厂:蔚来汽车的造车工厂有哪些?

具体来说&#xff0c;理想汽车目前在常州仅有一家汽车制造工厂。 一期项目于2017年12月竣工&#xff0c;2019年12月投产&#xff0c;年产能10万辆/年。 同时&#xff0c;正在规划二期工程。 产能将增至20万辆/年。 此外&#xff0c;理想还计划接管现代汽车在北京顺义的第一家工…

Xcode :Could not build module ‘WebKit‘ 已验证解决

问题&#xff1a;Could not build module WebKit 具体报错如下&#xff1a; error: type argument nw_proxy_config_t (aka struct nw_proxy_config *) is neither an Objective-C object nor a block type property (nullable, nonatomic, copy) NSArray<nw_proxy_config_…

Qt 中Qwidget相关属性

文章目录 1. QWidget 核心属性1.1 enabled1.2 geometry1.2.1 window frame 的影响 1.3 windowTitle1.4 windowIcon1.4.1 qrc的使用 1.5 windowOpacity1.6 cursor1.7 focusPolicy1.8 styleSheet 1. QWidget 核心属性 在 Qt 中, 使⽤ QWidget 类表⽰ “控件”. 像按钮, 视图, 输…

Vue3自定义文章列表组件

一、Vue3的代码展示 <template><div><div v-for"article in articles" :key"article.id" class"article-card"><div class"author-info"><img :src"article.avatar" alt"Author Avatar&qu…