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,整体分为两大轮遍历逻辑。
第一轮遍历:统计所有偶数的出现次数
- 初始化空哈希映射
cnt,key存偶数数值,value存该偶数出现次数。 - 依次取出数组每一个元素,逐个判断是否为偶数,只对偶数做计数累加:
- 元素3:3÷2余1,是奇数,跳过,不存入映射。
- 元素4:4是偶数,映射中无4,
cnt[4]赋值为1。此时映射:{4:1}。 - 元素2:2是偶数,映射中无2,
cnt[2]赋值为1。此时映射:{4:1, 2:1}。 - 元素5:5÷2余1,是奇数,跳过。
- 元素4:4是偶数,映射已有4,
cnt[4]在原有基础上加1,变为2。此时映射:{4:2, 2:1}。 - 元素6:6是偶数,映射中无6,
cnt[6]赋值为1。最终完整映射:{4:2, 2:1, 6:1}。
- 第一轮遍历结束,映射里保存了数组全部偶数各自出现的总次数,奇数完全不参与统计。
第二轮遍历:按原数组顺序查找第一个仅出现1次的偶数
再次从头到尾遍历原数组,按元素原始先后顺序校验条件,满足则直接返回,不再继续遍历:
- 元素3:奇数,直接跳过,不判断次数。
- 元素4:偶数,去映射查
cnt[4]=2,出现次数不为1,不符合,跳过。 - 元素2:偶数,去映射查
cnt[2]=1,同时满足两个条件:偶数、仅出现一次,符合题目要求。 - 立刻终止本轮遍历,直接把数字2作为函数结果返回,后续元素5、4、6不再处理。
main主函数流程
- 定义输入数组
nums = [3,4,2,5,4,6]。 - 调用
firstUniqueEven函数,传入数组,接收返回结果2。 - 打印输出结果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;}