当前位置: 首页 > article >正文

Leetcode经典题目之“双指针交换元素“类题目

1 LC 27. 移除元素

class Solution {
    public int removeElement(int[] nums, int val) {
        int n=nums.length;

        int s=0;

        for(int i=0;i<n;i++){
        	// 只有不等于目标值的时候才会进行交换,然后移动s指针
            if(nums[i]!=val){
                swap(nums,i,s++);
            }
        }
        return s;
    }
    void swap(int[]nums, int i, int j){
        int t=nums[i];
        nums[i]=nums[j];
        nums[j]=t;
    }
}

2 LC 删除有序数组中的重复项

class Solution {
    public int removeDuplicates(int[] nums) {
        int n=nums.length;
        int s=0;
        for(int i=1;i<n;i++){
        	// 这个if条件也可以换成if(nums[i-1]!=nums[i]), 但是写成下面这样更方便理解,
        	// 因为
            if(nums[s]!=nums[i]){
                nums[++s]=nums[i];
            }
        }
        return ++s;
    }
}

3 LC80. 删除有序数组中的重复项 II

参考解析:双指针解法
在这里插入图片描述

    public int removeDuplicates(int[] nums) {
        int n=nums.length;
        if(n<2){
            return n;
        }
        int s=2,f=2;
        while(f<n){
            if(nums[s-2]!=nums[f]){
                nums[s++]=nums[f];
            }
            f++;
        }
        return s;
    }

4 LC912. 快速排序数组:涉及到划分区间的问题,比如将小于等于目标值的元素都移动到左边,大于目标值的元素都移动到右边。参考下面的partition方法

  public int[] sortArray(int[] nums) {
        quickSort3(nums,0,nums.length-1);
        return nums;
    }

    void quickSort3(int[]arr,int i, int j) {
        if(i>=j)return;

        int pivot=partition(arr,i,j);
        quickSort3(arr,i,pivot-1);
        quickSort3(arr,pivot+1,j);
    }

    int partition(int[]arr,int l, int r){
        Random rand=new Random();
        int pivot = rand.nextInt(r-l+1)+l;
        swap(arr,pivot,r);
        
        int i=l-1;
        for(int j=l;j<r;j++){
        	// 符合条件的才进行移动,对指针
            if(arr[j]<=arr[r]){
                swap(arr,++i,j);
            }
        }
        swap(arr,r,++i);
        return i;
    }
    void quickSort(int[]arr,int i, int j) {
        if(i>=j){
            return;
        }
        int base=arr[i];
        int p=i,q=j;
        for(int k=i+1;k<=q;){
            if(arr[k]<base){
                swap(arr,k,p);
                p++;
                k++;
            }else if(arr[k]>base){
                swap(arr,k,q);
                q--;
            }else{
                k++;
            }
        }
        for(int k=i;k<=j;k++){
            System.out.print("k:"+k+","+arr[k]+" ");
        }
        quickSort(arr,i,p-1);
        quickSort(arr,q+1,j);

    }



http://www.kler.cn/a/133713.html

相关文章:

  • MySql结合element-plus pagination的分页查询
  • Android OpenGL ES详解——立方体贴图
  • 以色列支付龙头遭DDoS攻击,各地超市加油站等POS机瘫痪
  • 5G时代的关键元件:射频微波MLCCs市场前景广阔
  • 定时器(QTimer)与随机数生成器(QRandomGenerator)的应用实践——Qt(C++)
  • 将大型语言模型(如GPT-4)微调用于文本续写任务
  • 基于SSM的古董拍卖系统
  • 基础组件-流量回放平台设计
  • 单线程的JS中Vue导致的“线程安全”问题
  • 【FPGA】Verilog:实现 RS 触发器 | Flip-Flop | 使用 NOR 的 RS 触发器 | 使用 NAND 的 RS 触发器
  • VUE(一)
  • Chrome 浏览器经常卡死问题解决
  • linux配置固定ip(两种方法)
  • Leetcode—3.无重复字符的最长子串【中等】
  • 在线预览excel,luckysheet在vue项目中的使用
  • SpringBoot-AOP学习案例
  • 【WiFI问题自助】解决WiFi能连上但是没有网的问题
  • 车载以太网-传输层-UDP
  • Flutter笔记:拖拽手势
  • java使用 TCP 的 Socket API 实现客户端服务器通信
  • NSSCTF第12页(3)
  • PS学习笔记——视图调整
  • em/px/rem/vh/vw 的区别?
  • Activiti,Apache camel,Netflex conductor对比,业务选型
  • Page分页records有数据,但是total=0,解决办法
  • 服务器数据恢复—VMware虚拟化下误操作导致服务器崩溃的数据恢复案例