golang查找两个数组不同的元素_假设有两个数组,其中的元素都是数字,现在要对其排序...

c0ef0ee325f67f8c8fc41ccd249e3d40.png

假设有 number,group,两个数组,其中的元素都是数字,现在要对其排序排序的规则如下:
1.如果 group里面元素,存在于numbers了里面
2.要把出现在 group 内的数字 放在 number 的那些数字之前,注意排序

numbers = [8, 3 ,1, 2, 5,4,7,6]
group = {2,3,5,7}


分析了下,应该是优先级的问题,这里使用了元组排序的方法:

numbers = [8, 3 ,1, 2, 5,4,7,6] 
group = {2,3,5,7} 
tmp = [] 
for x in numbers:     
    if x in group:
        tmp.append((0, x))     
    else:         
        tmp.append((1, x)) 
tmp.sort() 
print(list(map(lambda x:x[1], tmp)))

在网上看到了一个经典的代码:

def sort_priority(values,group):
     def helper(x):
         if x in group: 
            return (0, x)         
         return (1, x)
     values.sort(key=helper)  
numbers = [8, 3 ,1, 2, 5,4,7,6]  
group = {2,3,5,7} 
sort_priority(numbers, group) print(numbers)


推荐使用第二个高阶函数的方法

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值