5. 算法编程练习:Find the unique number

Find the unique number

Instructions

There is an array with some numbers. All numbers are equal except for one. Try to find it!

find_uniq([ 1, 1, 1, 2, 1, 1 ]) == 2
find_uniq([ 0, 0, 0.55, 0, 0 ]) == 0.55


Sample Tests

try:
import codewars_test as test
except:
pass

@test.describe(“Basic Tests”)
def f():
@test.it(“Simple tests”)
def _():
test.assert_equals(find_uniq([ 1, 1, 1, 2, 1, 1 ]), 2)
test.assert_equals(find_uniq([ 0, 0, 0.55, 0, 0 ]), 0.55)
test.assert_equals(find_uniq([ 3, 10, 3, 3, 3 ]), 10)


orgorithm analysis

排序;遍历;取值判断


code

def find_uniq(arr = [2,2,2,2,3,2,2]):
    sort = sorted(arr)
    if sort[0] == sort[1]:
        return sort[-1]
    return sort[0] 

小结

set([iterable])内置函数,利用集合的性质去重是比较好的思路。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值