LeetCode刷题之 存在重复元素(题目分析➕源代码)

题目链接🔗力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

1. 题目分析

本题是要找到数组中的重复元素,所以我们分析出一下几点:

  1. bool是一种数据类型,true是非0值,false是0.。

  2. 数组中只要任意一个值出现两次及以上就返回true。

  3. 数组中每个元素都不同,也就是每个元素只出现一次就返回false。

2. 做题思路

我们首先想到的就是遍历两次数组,但是需要注意的是时间复杂度是O(N^2),我们这样写的代码是过不去的,因为当数组很大的时候,跑的会很慢,时间超过了限制。

所以我们在这里要放弃遍历的思想,那应该怎么解决呢?

作者想到的方法,利用希尔排序来解决问题,通过排序,找到相同的元素就返回1,如果当排序结束的时候还没有找到就返回0。下面就是代码啦!

2. 源代码

cpp 复制代码
int ShellSort(int* a,int n)
{
    int gap = n;
    int ret = 0;
    while(gap > 1)
    {
        gap = gap / 2;
        for (int i = 0; i < n-gap; ++i)
        {
            int end = i;
            int tmp = a[end+gap];
            while(end >= 0)
            {
                if(a[end] > tmp)
                {
                    a[end+gap] = a[end];
                    end = end - gap;
                }
                else if(a[end] == tmp)
                {
                    ret = 1;
                    return ret;
                }
                else
                    break;
            }
            a[end+gap] = tmp;
        }
    }
    return ret;
}
bool containsDuplicate(int* nums, int numsSize)
{
    return ShellSort(nums,numsSize);
}
相关推荐
Han.miracle2 小时前
数据结构——二叉树的从前序与中序遍历序列构造二叉树
java·数据结构·学习·算法·leetcode
mit6.8244 小时前
前后缀分解
算法
你好,我叫C小白4 小时前
C语言 循环结构(1)
c语言·开发语言·算法·while·do...while
寂静山林7 小时前
UVa 10228 A Star not a Tree?
算法
Neverfadeaway7 小时前
【C语言】深入理解函数指针数组应用(4)
c语言·开发语言·算法·回调函数·转移表·c语言实现计算器
Madison-No78 小时前
【C++】探秘vector的底层实现
java·c++·算法
Swift社区8 小时前
LeetCode 401 - 二进制手表
算法·leetcode·ssh
派大星爱吃猫8 小时前
顺序表算法题(LeetCode)
算法·leetcode·职场和发展
liu****8 小时前
8.list的模拟实现
linux·数据结构·c++·算法·list
地平线开发者9 小时前
征程 6 | 征程 6 工具链如何支持 Matmul/Conv 双 int16 输入量化?
算法·自动驾驶