当前位置: 首页 > news >正文

【剑指offer--C/C++】JZ3 数组中重复的数字

一、题目

这里是引用

二、本人思路及代码

这道题目它要求的时间空间利用率都是n,那么可以考虑创建一个长度为n的数组repeat初始化为0,下标代码出现的数字,下标对应的数组内容代表该下标数字出现的次数。然后遍历提供的数组,每出现一个数字,就去repeat数组下标对应位置内容+1,然后判断如果已经>1了,那说明重复了,直接返回这个下标数字即可。

/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param numbers int整型一维数组 * @param numbersLen int numbers数组长度* @return int整型*/
int duplicate(int* numbers, int numbersLen ) {// write code here//int repeat[numbersLen]={0};int *repeat = (int*) malloc (numbersLen * sizeof(int));for(int j=0;j<numbersLen;j++) repeat[j]=0;for(int i=0;i<numbersLen;i++){int n=numbers[i];if(n>=numbersLen){return -1;}else {repeat[n]++;if(repeat[n]>1){return n;}}}return -1;
}

三、疑问

这里为什么不能直接创建一个长度为numbersLen的数组呢? 编译报错说是numbersLen是一个会变的数字,不能用它作为数组长度,可是,当运行到这个子函数内部并创建数组的时候,numbersLen不是一个已知的且在子函数退出之前固定不变的数吗?

http://www.lryc.cn/news/310409.html

相关文章:

  • 基于SpringBoot的在线拍卖系统设计与实现(源码)
  • 卢森堡比利时土耳其媒体宣发稿助力跨境出海推广新闻营销
  • 冒泡排序(C语言详解)
  • STC-ISP原厂代码研究之 V3.7d汇编版本
  • 【word】引用文献如何标注右上角
  • MySQL 5.5、5.6、5.7的主从复制改进
  • 性能分析排查思路之日志(1)
  • Vue中如何实现条件渲染?
  • Postman上传文件的操作方法
  • linux系统Jenkins工具介绍
  • 【python】遵守 robots.txt 规则的数据爬虫程序
  • 使用爬虫去获取四六级成绩
  • 洛谷P1256 显示图像
  • 模拟器抓HTTP/S的包时如何绕过单向证书校验(XP框架)
  • 【JS 算法题: 将 json 转换为字符串】
  • 数的范围 刷题笔记
  • XSS简介及xsslabs第一关
  • 构建安全的REST API:OAuth2和JWT实践
  • 从0开始学习NEON(1)
  • (二十三)Flask之高频面试点
  • 设计模式(十三)抽象工厂模式
  • HTTP Cookie 你了解多少?
  • 【QT+QGIS跨平台编译】之五十六:【QGIS_CORE跨平台编译】—【qgsmeshcalclexer.cpp生成】
  • ar时间序列
  • Android 14 AAOS audio
  • 文心一言 VS 讯飞星火 VS chatgpt (207)-- 算法导论15.4 4题
  • 【论文笔记】Attention Is All You Need
  • (亲测可用)Adobe Photoshop 2024下载与安装
  • uniapp聊天记录本地存储(详细易懂)
  • Vue.js中的$nextTick