代码改变世界

面试题:给定一个长度为N的数组,其中每个元素的取值范围都是1到N。判断数组中是否有重复的数字

  youxin  阅读(8669)  评论(2编辑  收藏  举报

题目:定一个长度为N的数组,其中每个元素的取值范围都是1到N。判断数组中是否有重复的数字。(原数组不必保留)

方法1.
对数组进行排序(快速,堆),然后比较相邻的元素是否相同。
时间复杂度为O(nlogn),空间复杂度为O(1)。

方法2.
使用bitmap方法。
定义长度为N/8的char数组,每个bit表示对应数字是否出现过。遍历数组,使用 bitmap对数字是否出现进行统计。
时间复杂度为O(n),空间复杂度为O(n)。

方法3.
遍历数组,假设第 i 个位置的数字为 j ,则通过交换将 j 换到下标为 j 的位置上。直到所有数字都出现在自己对应的下标处,或发生了冲突。
时间复杂度为O(n),空间复杂度为O(1)。

方法3示例代码如下

复制代码
#include<iostream>
#include<ctime>
using namespace std;
//判断数组中是否包含重复数字
const int MAX= 10;

bool isDuplicate(int val[])
{
    for(int i=0;i<MAX;i++)
    {
        if(val[i]!=i)
        {
            if(val[i] != val[val[i]])
                swap(val[i],val[val[i]]);
            else
                return true;
        }
    }
    return false;
}

int main()
{
    int val[MAX];
    srand((unsigned)time(NULL));

    cout<<"init data:"<<endl;
    for(int i=0;i<MAX;i++)
    {
        int tmp=rand()%MAX;
        val[i]=tmp;
        cout<<tmp<<" ";
    }
    cout<<endl;
    bool flag=isDuplicate(val);

     if(flag)  
        cout << "has duplicate elem" << endl;  
    else  
        cout << "no duplicate elem" << endl;  

}
复制代码

srand((unsigned)time(NULL));

time()头文件为ctime.这句话不要程序每次运行结果都一样。

 

编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
历史上的今天:
2012-09-02 javascript同源策略
2012-09-02 javascript和php传递数据
2012-09-02 ajax cross-domain 跨域问题
2012-09-02 js document.write 总结
2012-09-02 ajax post 方法
2012-09-02 转:javascript对json操作讲解
2012-09-02 javascript获取网页URL地址及参数等
点击右上角即可分享
微信分享提示