剑指offer--数组中重复的数字

一.题目描述

在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。


算法1.排序,然后遍历,时间复杂度O(nlogn),空间O(logn)

c 复制代码
int Cmp_int(const void* vp1, const void* vp2)
{
    return *(int*)vp1 - *(int*)vp2;
}
int findRepeatNumber1(int* nums, int numsSize)
{
    qsort(nums,numsSize,sizeof(int),Cmp_int);//调用排序算法,需要引用stdlib.h
    for (int i = 0; i+1 < numsSize; i++)
    {
        if (nums[i] == nums[i + 1])
            return nums[i];
    }
    return -1;
}

算法2:利用哈希表,时间O(n),空间O(n)

cpp 复制代码
int findRepeatNumber(int* nums, int numsSize)
{
    int* arr = (int*)malloc(numsSize * sizeof(int));
    int i;
    int m;
    for (i = 0; i < numsSize; i++)
        arr[i] = -1;//-1表示无效值
    for (i = 0; i < numsSize; i++)
    {
        m = nums[i];
        if (arr[m] != -1)//找到了
        {
            free(arr);
            return m;
        }
        arr[m] = m;
    }
    free(arr);
    return -1;//没有重复的
}

算法3.数据归位(把m存放到nums[m]位置)

cpp 复制代码
int findRepeatNumber3(int* nums, int numsSize) //O(n),O(1)

{
    int m; 
    for (int i = 0; i < numsSize; i++) 
    {
        while (nums[i] != i)//当前位置,存放的不是当前数据,交换 
        {
            m = nums[i]; 
            if (m == nums[m])//找到了 
                return m; 
            nums[i] = nums[m]; 
            nums[m] = m; 
        }
    }
    return -1; 
}

int main() 
{
    int nums[] = { 2, 3, 1, 0, 2, 5, 3 }; 
    printf("%d\n", findRepeatNumber(nums,sizeof(nums)/sizeof(nums[0])));


    return  0; 
}

本篇完!

相关推荐
IT大白鼠3 小时前
AIGC性能的关键瓶颈:算力、数据、算法三者如何互相制约?
算法·aigc
白雪茫茫3 小时前
监督学习、半监督学习、无监督学习算法详解
python·学习·算法·ai
FengyunSky3 小时前
浅析 空间频率响应 SFR 计算
算法
树下水月3 小时前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集4 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考5 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
流年如夢5 小时前
单链表进阶版 -->双向链表
数据结构·链表
刀法如飞6 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
流年如夢7 小时前
单链表 -->增、删、查、改等详细操作
c语言·数据结构
sali-tec7 小时前
C# 基于OpenCv的视觉工作流-章66-直线夹角
图像处理·人工智能·opencv·算法·计算机视觉