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);
}
相关推荐
利刃大大2 小时前
【回溯+剪枝】找出所有子集的异或总和再求和 && 全排列Ⅱ
c++·算法·深度优先·剪枝
皮卡丘のcoding3 小时前
蓝桥杯备赛练习题01
职场和发展·蓝桥杯
Rachela_z3 小时前
代码随想录算法训练营第十四天| 二叉树2
数据结构·算法
细嗅蔷薇@3 小时前
迪杰斯特拉(Dijkstra)算法
数据结构·算法
追求源于热爱!3 小时前
记5(一元逻辑回归+线性分类器+多元逻辑回归
算法·机器学习·逻辑回归
不过四级不改名6773 小时前
蓝桥杯嵌入式uart,iic,adc_scan模版
职场和发展·蓝桥杯
ElseWhereR3 小时前
C++ 写一个简单的加减法计算器
开发语言·c++·算法
Smark.4 小时前
Gurobi基础语法之 addConstr, addConstrs, addQConstr, addMQConstr
算法
S-X-S4 小时前
算法总结-数组/字符串
java·数据结构·算法
Joyner20185 小时前
python-leetcode-从中序与后序遍历序列构造二叉树
算法·leetcode·职场和发展