当前位置:   article > 正文

力扣--260只出现一次的数字I-III_力扣260只出现一次的数字c语言

力扣260只出现一次的数字c语言

题目I

在这里插入图片描述

Python 代码

1 利用字典计数

def singleNumber(self,nums):
    dict={}
    for i in nums:
        if i not in dict:
            dict[i]=1
        else:
            dict[i]+=1
    for key, value in dict.items():
        if value==1:
            return key
    return 0
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

在这里插入图片描述

2 排序比较判断

def singleNumber(self,nums):
    nums.sort()
    length = len(nums)
    if length < 3:
        return nums[0]
    i = 0
    while i < length - 2 :
        if nums[i] != nums[i+1]:
            return nums[i]
        else:
            i += 2
    return nums[-1]
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

Z

3 集合交叉法

def singleNumber(self, nums):        
    nums.sort()        
    n = list(set(nums[::2]) - set(nums[1::2]))[0]        
    return n
  • 1
  • 2
  • 3

在这里插入图片描述

题目II

在这里插入图片描述

python代码

def singleNumber(self,nums):
    dict={}
    for i in nums:
        if i not in dict:
            dict[i]=1
        else:
            dict[i]+=1
    for key, value in dict.items():
        if value==1:
            return key
    return 0
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

在这里插入图片描述

题目III

在这里插入图片描述

python代码

def singleNumber(self,nums):
    dict={}
    nums_new=[]
    for i in nums:
        if i not in dict:
            dict[i]=1
        else:
            dict[i]+=1
    for key, value in dict.items():
        if value==1:
            nums_new.append(key)
    return nums_new
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/50551
推荐阅读
相关标签
  

闽ICP备14008679号