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

2026-07-04:找到第一个唯一偶数。用go语言,在数组 nums 中寻找这样的数:它是偶数(能被 2 整除),并且在 nums 里只出现一次。请返回满足条件的那个偶数的值,并且以其在数组中的首次

2026-07-04:找到第一个唯一偶数。用go语言,在数组 nums 中寻找这样的数:它是偶数(能被 2 整除),并且在 nums 里只出现一次。请返回满足条件的那个偶数的值,并且以其在数组中的首次出现位置最靠前为准;如果数组中不存在这种偶数,返回 -1。

1 <= nums.length <= 100。

1 <= nums[i] <= 100。

输入: nums = [3,4,2,5,4,6]。

输出: 2。

解释:

2 和 6 都是偶数,并且它们都恰好出现一次。因为 2 在数组中出现得更早,所以答案是 2。

题目来自力扣3866。

一、函数执行分步详细过程(输入数组:[3,4,2,5,4,6])

函数目标:找出数组里第一个只出现一次的偶数,无符合条件数字返回-1,整体分为两大轮遍历逻辑。

第一轮遍历:统计所有偶数的出现次数

  1. 初始化空哈希映射cnt,key存偶数数值,value存该偶数出现次数。
  2. 依次取出数组每一个元素,逐个判断是否为偶数,只对偶数做计数累加:
    1. 元素3:3÷2余1,是奇数,跳过,不存入映射。
    2. 元素4:4是偶数,映射中无4,cnt[4]赋值为1。此时映射:{4:1}
    3. 元素2:2是偶数,映射中无2,cnt[2]赋值为1。此时映射:{4:1, 2:1}
    4. 元素5:5÷2余1,是奇数,跳过。
    5. 元素4:4是偶数,映射已有4,cnt[4]在原有基础上加1,变为2。此时映射:{4:2, 2:1}
    6. 元素6:6是偶数,映射中无6,cnt[6]赋值为1。最终完整映射:{4:2, 2:1, 6:1}
  3. 第一轮遍历结束,映射里保存了数组全部偶数各自出现的总次数,奇数完全不参与统计。

第二轮遍历:按原数组顺序查找第一个仅出现1次的偶数

再次从头到尾遍历原数组,按元素原始先后顺序校验条件,满足则直接返回,不再继续遍历:

  1. 元素3:奇数,直接跳过,不判断次数。
  2. 元素4:偶数,去映射查cnt[4]=2,出现次数不为1,不符合,跳过。
  3. 元素2:偶数,去映射查cnt[2]=1,同时满足两个条件:偶数、仅出现一次,符合题目要求。
  4. 立刻终止本轮遍历,直接把数字2作为函数结果返回,后续元素5、4、6不再处理。

main主函数流程

  1. 定义输入数组nums = [3,4,2,5,4,6]
  2. 调用firstUniqueEven函数,传入数组,接收返回结果2。
  3. 打印输出结果2。

边界补充逻辑(无匹配偶数场景)

如果第二轮完整走完数组,全程没有找到“偶数且次数为1”的数字,函数最后执行return -1

二、复杂度分析

设数组长度为 n(题目约束1 ≤ n ≤ 100)

1. 时间复杂度

  • 第一轮遍历数组:循环执行 n 次,O(n)
  • 第二轮遍历数组:最坏情况完整循环 n 次,O(n)
    两次线性遍历相加,总时间复杂度:O(n)

2. 额外空间复杂度

额外开辟了哈希映射存储偶数计数。数组元素取值范围1~100,偶数最多50个,映射存储元素数量固定有上限,和输入数组长度n无关。
因此总额外空间复杂度:O(1)(常数级空间)

Go完整代码如下:

packagemainimport("fmt")funcfirstUniqueEven(nums[]int)int{cnt:=map[int]int{}for_,x:=rangenums{ifx%2==0{cnt[x]++}}for_,x:=rangenums{ifx%2==0&&cnt[x]==1{returnx}}return-1}funcmain(){nums:=[]int{3,4,2,5,4,6}result:=firstUniqueEven(nums)fmt.Println(result)}

Python完整代码如下:

# -*-coding:utf-8-*-deffirst_unique_even(nums):cnt={}forxinnums:ifx%2==0:cnt[x]=cnt.get(x,0)+1forxinnums:ifx%2==0andcnt.get(x)==1:returnxreturn-1if__name__=="__main__":nums=[3,4,2,5,4,6]result=first_unique_even(nums)print(result)

C++完整代码如下:

#include<iostream>#include<vector>#include<unordered_map>intfirstUniqueEven(conststd::vector<int>&nums){std::unordered_map<int,int>cnt;for(intx:nums){if(x%2==0){cnt[x]++;}}for(intx:nums){if(x%2==0&&cnt[x]==1){returnx;}}return-1;}intmain(){std::vector<int>nums={3,4,2,5,4,6};intresult=firstUniqueEven(nums);std::cout<<result<<std::endl;return0;}

http://www.gsyq.cn/news/1640543.html

相关文章:

  • Python3面向对象001
  • c++数据结构竞赛 -常见排序(没有归并和快速排序)
  • Android图片解码器libjpeg-turbo vs Skia最佳实践
  • 使用SVN+CruiseControl+ANT实现持续集成之一
  • 语法:变量
  • CompressO:5分钟学会用这款免费开源工具,将视频文件缩小90%
  • 数据自动刷新
  • 深度解析Rainmeter桌面自定义工具:从核心架构到插件开发实践
  • CodeCombat终极指南:如何通过游戏化学习掌握真实编程技能
  • HCI 功能规范【5.1. Correctness】
  • 图吧工具箱+自动化:运维效率提升神器
  • 抖音无水印视频下载终极指南:三步搞定批量下载难题
  • 荣耀出征手游官网下载:荣耀出征最新官方下载渠道及新手开荒攻略
  • 下服务器端开发流程及相关工具介绍(C++)
  • 基于WSEN-ISDS和TM4C129的三轴运动追踪系统设计
  • 【Java项目-企悦抽】02-AI赋能产品需求规格说明书
  • 医用修护敷料选购指南:资质、成分与剂型的硬核拆解
  • TensorRT量化模型部署实战:从QAT到INT8推理的工程陷阱
  • 第十八周小学期
  • 前端工程化-02:一个完整的vue工程结构模板
  • 开源商城源码下载后能商用吗?这3款Apache-2.0协议商城放心用
  • 卫星被云挡住后,AI还能知道洪水淹到哪里吗?
  • 高精度电压管理系统设计与STM32实现
  • 纯电动汽车骑车辅件介绍
  • 大模型技术实战:AIGC与Agent智能体开发指南
  • 总目录 2026版国家级全领域科研痛点攻关
  • 1:配置git
  • Claude Code 会话上下文管理,长会话不失控的三把刀
  • 基于LangChain+Redis构建会话持久化的智能 Agent系统
  • 在半导体功率循环测试以及热特性表征中,从测试得到的VCE 曲线推导热阻Rth和时间常数谱是核心技术