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);
}
相关推荐
budingxiaomoli3 分钟前
动态规划--斐波那契数列模型
算法·动态规划
IT猿手7 分钟前
多目标优化算法:多目标蛇优化算法(Multiple Objective Snake Optimizer,MOSO)(提供MATLAB代码)
开发语言·算法·matlab·动态路径规划·光伏模型参数估计
MegaDataFlowers24 分钟前
101.对称二叉树
算法
Jasmine_llq43 分钟前
《B3939 [GESP样题 四级] 绝对素数》
数据结构·算法·素数判断算法·数字拆分与反转算法·区间遍历枚举·双条件判断逻辑
郝学胜-神的一滴1 小时前
干货版《算法导论》07:递归视角下的选择排序与归并排序
java·数据结构·c++·python·程序人生·算法·排序算法
csdn_aspnet1 小时前
javascript 算法 LeetCode 编号 70 - 爬楼梯
开发语言·javascript·算法·leetcode·ecmascript
shehuiyuelaiyuehao1 小时前
多线程入门
java·python·算法
Navigator_Z1 小时前
LeetCode //C - 1073. Adding Two Negabinary Numbers
c语言·算法·leetcode
醇氧1 小时前
【OpenClaw】更换阿里百炼完整配置指南
算法·ai
Tina学编程2 小时前
[HOT100]每日一练------最长连续序列
算法·hot 100