IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 《LeetCode刷题》—448. 找到所有数组中消失的数字 -> 正文阅读

[数据结构与算法]《LeetCode刷题》—448. 找到所有数组中消失的数字

《LeetCode刷题》—448. 找到所有数组中消失的数字

一、题目内容

原题连接:https://leetcode.cn/problems/find-all-numbers-disappeared-in-an-array/

题目:

在这里插入图片描述

二、个人答案(Java)

思路:先排序,再查找,用到Arrays工具类中的sort方法和binarySearch方法,举例,给一个数组【1,2,3,5,6,7】总共长度为6,求在1-6当中的数,但是又没有在该数组当中的数,并且以集合方式返回,那么先新建一个集合list用于存放,然后遍历给的数组,用binarySearch方法去从1开始到数组长度结束,挨个看在不在,不在就返回一个负数,判断返回值为负数就放进一开始建的数组里面去

方法

  1. int binarySearch(int[] a,int key):对排序后的数组进行二分法检索指定的值(查找不到则返回负数)
  2. 4.void sort(int[] a):对数组进行排序

在这里插入图片描述

代码

class Solution1111 {
    public List<Integer> findDisappearedNumbers(int[] nums) {
        ArrayList list = new ArrayList();
        Arrays.sort(nums);
        for (int i = 1; i <= nums.length; i++) {
            int temp = Arrays.binarySearch(nums, i);
            if (temp < 0) {
                list.add(i);
            }
        }

        return list;

    }
}

三、官方答案(Java)

方法一:原地修改

思路:

在这里插入图片描述

class Solution {
    public List<Integer> findDisappearedNumbers(int[] nums) {
        int n = nums.length;
        for (int num : nums) {
            int x = (num - 1) % n;
            nums[x] += n;
        }
        List<Integer> ret = new ArrayList<Integer>();
        for (int i = 0; i < n; i++) {
            if (nums[i] <= n) {
                ret.add(i + 1);
            }
        }
        return ret;
    }
}

官方答案来源:

作者:LeetCode-Solution
链接:https://leetcode.cn/problems/find-all-numbers-disappeared-in-an-array/solution/zhao-dao-suo-you-shu-zu-zhong-xiao-shi-d-mabl/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-10-17 12:59:49  更:2022-10-17 13:04:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/23 23:26:48-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码