logo头像
Snippet 博客主题

【Leetcode 137】Single NumberII

难度: 中等(Medium)

题目

Given an array of integers, every element appears three times except for one. Find that single one.

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class Solution(object):
def singleNumber(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
ones = [0]*32
negative = 0
for n in nums:
if bin(n)[0] == '-':
n = bin(n)[3:]
negative = (negative+1)%3
else:
n = bin(n)[2:]
for i in range(0,len(n)):
if n[i] == '1':
ones[32-(len(n)-i)] = (ones[32-(len(n)-i)] + 1)%3
res = int(''.join([str(one) for one in ones]),2)
if negative == 1:
res = -res
return res

评论系统未开启,无法评论!