剑指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; 
}

本篇完!

相关推荐
历程里程碑14 分钟前
各种排序法大全
c语言·数据结构·笔记·算法·排序算法
少许极端23 分钟前
算法奇妙屋(十四)-简单多状态dp问题
算法·动态规划·图解算法·简单多状态dp·打家劫舍问题·买卖股票问题全解
2301_823438021 小时前
解析论文《复杂海上救援环境中无人机群的双阶段协作路径规划与任务分配》
人工智能·算法·无人机
embrace991 小时前
【C语言学习】结构体详解
android·c语言·开发语言·数据结构·学习·算法·青少年编程
Ayanami_Reii2 小时前
基础数学算法-开关问题
数学·算法·高斯消元
稚辉君.MCA_P8_Java2 小时前
通义 Go 语言实现的插入排序(Insertion Sort)
数据结构·后端·算法·架构·golang
稚辉君.MCA_P8_Java3 小时前
Gemini永久会员 Go 实现动态规划
数据结构·后端·算法·golang·动态规划
腾讯云开发者3 小时前
数据与 AI 双向奔赴,腾讯云架构师技术沙龙精彩回顾
数据结构
快手技术3 小时前
快手 & 南大发布代码智能“指南针”,重新定义 AI 编程能力评估体系
算法
Murphy_lx3 小时前
C++ std_stringstream
开发语言·c++·算法