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

【Java SE 题库】移除元素(暴力解法)--力扣

 🔥博客主页🔥:【 坊钰_CSDN博客 】

欢迎各位点赞👍评论✍收藏⭐

目录

1. 题目

2. 解法(快慢“指针”) 

3. 源码

4. 小结


1. 题目

给你一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。

假设 nums 中不等于 val 的元素数量为 k,要通过此题,您需要执行以下操作:

  • 更改 nums 数组,使 nums 的前 k 个元素包含不等于 val 的元素。nums 的其余元素和 nums 的大小并不重要。
  • 返回 k

 例:

输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2,_,_]
输入:nums = [0,1,2,2,3,0,4,2], val = 2
输出:5, nums = [0,1,4,0,3,_,_,_]

2. 解法(快慢“指针”) 

当然 Java 里是没有指针的,这里只是类比一下

我们想一下这是一个数组,我们要原地删除数字 2

 我们先用 str 和 des 来类比指针,他俩都指向第一个位置

以 des 指针向后遍历

1,遇到的数字不等于 2 ,把des指向的数字赋值给str,des++ ,str++,都往后移动一位

2, 遇到的数字等于 2,des++

3. 源码

import java.util.Scanner;

class Solution {
    public static int removeElement (int[] arr,int val) {
        int sz=arr.length;
        int des=0;
        int str=0;
        for(int i=0;i<sz;i++) {
            if(arr[des]!=val) {
                arr[str++]=arr[des++];    //判断条件
            } else {
                des++;
            }
        }
        return str;
    }

    public static void Print(int[] arr,int n) {
        for(int i=0;i<n;i++) {
            System.out.print(arr[i]+" ");    // 打印数组
        }
        System.out.println(" ");
    }
}

public class TeatDelete {
    public static void main(String[] args) {
    int[] arr={1,2,3,4,4,3,2,2,6,2};
    Scanner val =new Scanner(System.in);
    int a=val.nextInt();
    int ret=Solution.removeElement(arr,a);
    Solution.Print(arr,ret);
    }
}

 

4. 小结

以上就是对移除元素的了解,具体还需宝子们去实践,如果觉得该博客对你有用的话,希望一键三连,点个关注不迷路,谢谢支持!

 


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

相关文章:

  • 如何建设一个企业级的数据湖
  • 深度学习项目--基于LSTM的糖尿病预测探究(pytorch实现)
  • arm-linux平台、rk3288 SDL移植
  • 将 OneLake 数据索引到 Elasticsearch - 第二部分
  • GitHub Actions 使用需谨慎:深度剖析其痛点与替代方案
  • rust 自定义错误(十二)
  • 室内定位论文整理-20240925期
  • 计算机毕业设计党建学习网站查看发布党建评论留言搜索部署安装/springboot/javaWEB/J2EE/MYSQL数据库/vue前后分离小程序
  • 【SpringCloud】多机部署, 负载均衡-LoadBalance
  • 使用 Seaborn 热图的 5 种方法(Python 教程)
  • Vue+Flask
  • Pencils Protocol 全面推动市场,生态通证 DAPP 将持续通缩
  • 【数据结构初阶】排序算法(下)冒泡排序与归并排序
  • Jupyter Notebook 产生 jupyter_notebook_config.py 配置文件
  • Html jquery下拉select美化插件——selectFilter.js
  • C++网络编程之IP地址和端口
  • 看似容易赚钱的炒股真的赚钱吗
  • 行为设计模式 -模板方法模式- JAVA
  • 计算机毕业设计 养老院管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解
  • 59 双向循环神经网络_by《李沐:动手学深度学习v2》pytorch版
  • 在2核2G服务器安装部署MySQL数据库可以稳定运行吗?
  • 武汉正向科技格雷母线公司,无人天车系统,采用格雷母线定位技术
  • 如何排查 Windows 无法连接ubuntu远程服务器
  • ScrapeGraphAI 大模型增强的网络爬虫
  • “Xian”(籼)和“Geng”(粳)米怎么读?
  • 戴尔电脑怎么开启vt虚拟化_戴尔电脑新旧机型开启vt虚拟化教程