剑指offer之找出数组中重复数字

举报
chenyu 发表于 2021/07/27 00:38:22 2021/07/27
【摘要】 1 问题 给的N个数字的数组,每个元素的大小范围大于等于0小于N(0 << a[i] < N),找出数组中有哪些数字重复了并且这个数字重复了多少次,一共有几个数字重复了。           2思路 由于元素的大小范围大于等于0小于N(0 << a[i] < N),我们直接把...

1 问题

给的N个数字的数组,每个元素的大小范围大于等于0小于N(0 << a[i] < N),找出数组中有哪些数字重复了并且这个数字重复了多少次,一共有几个数字重复了。

 

 

 

 

 

2思路

由于元素的大小范围大于等于0小于N(0 << a[i] < N),我们直接把这个元素的大小作为下标(不会小标越界),每出现一次就是把这个元素的大小作为下标的值进行增加1,然后最后去判断新数组的值是否大于1

 

 

 

 

3 代码实现


  
  1. #include <iostream>
  2. #include <stdlib.h>
  3. using namespace std;
  4. int main()
  5. {
  6. std::cout << "请输入N个数字" << std::endl;
  7. int n = 0;
  8. std::cin >> n;
  9. std::cout << std::endl;
  10. if (n <= 0) {
  11. std::cout << "输入的数字错误" << std::endl;
  12. return -1;
  13. }
  14. int *a = new int[n];
  15. //初始化数组
  16. memset(a, 0, n * sizeof(int));
  17. std::cout << "分别输入每个数字的值" << std::endl;
  18. for (int i = 0; i < n; ++i)
  19. {
  20. int num = 0;
  21. std::cin >> num;
  22. if (num < 0 || num >= n)
  23. {
  24. std::cout << "输入的数字值" << a[i] << "不对" << std::endl;
  25. return -1;
  26. }
  27. a[num]++;
  28. }
  29. int count = 0;
  30. for (int i = 0; i < n; ++i)
  31. {
  32. if (a[i] > 1)
  33. {
  34. ++count;
  35. std::cout << "数字" << i << "重复" << a[i] << "次" << std::endl;
  36. }
  37. }
  38. std::cout << "总共重复的数字有" << count << "个" << std::endl;
  39. delete[] a;
  40. return 0;
  41. }

 

 

 

 

 

4 运行结果


  
  1. 请输入N个数字
  2. 15
  3. 分别输入每个数字的值
  4. 2
  5. 3
  6. 4
  7. 5
  8. 4
  9. 3
  10. 2
  11. 2
  12. 3
  13. 5
  14. 5
  15. 5
  16. 5
  17. 6
  18. 6
  19. 数字2重复3次
  20. 数字3重复3次
  21. 数字4重复2次
  22. 数字5重复5次
  23. 数字6重复2次
  24. 总共重复的数字有5个

 

 

 

5 总结

我们要记得把值作为数组下标的方法(前提不会下标越界),然后在C和C++中如果要有动态数组,我们需要new和malloc,我们不能这样写


  
  1. nt n = 0;
  2. scanf("%d\n", &n);
  3. int a[n] = {0};
  4. int n = 0;
  5. std::cin >> n >> std::endl;
  6. int a[n] = {0};

不然编译会提示如下

variable-sized object may not be initialized
 

但是在java里面是可以这样写的,要注意。

 

文章来源: chenyu.blog.csdn.net,作者:chen.yu,版权归原作者所有,如需转载,请联系作者。

原文链接:chenyu.blog.csdn.net/article/details/85967756

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。