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);
}
相关推荐
不知天地为何吴女士44 分钟前
Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法
小坏坏的大世界1 小时前
C++ STL常用容器总结(vector, deque, list, map, set)
c++·算法
励志要当大牛的小白菜3 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970443 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵4 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
爱喝矿泉水的猛男6 小时前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展
YuTaoShao6 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
YouQian7727 小时前
Traffic Lights set的使用
算法
go54631584658 小时前
基于深度学习的食管癌右喉返神经旁淋巴结预测系统研究
图像处理·人工智能·深度学习·神经网络·算法
aramae9 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法