面试题:给定一个长度为N的数组,其中每个元素的取值范围都是1到N。判断数组中是否有重复的数字
2013-09-02 22:49 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.这句话不要程序每次运行结果都一样。
:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于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地址及参数等