py.CheckiO刷题—O‘REILLY岛:Sort Except Zero

这篇博客讨论了如何在排序数组时保持指定元素(如0)不变的两种方法。第一种方法使用选择排序,当遇到指定元素时跳过;第二种方法先删除指定元素再重新插入。提供的代码示例展示了这两种实现方式,并给出了测试用例。
摘要由CSDN通过智能技术生成

题目背景:

对数组中的数字进行排序。但是零的位置不应该改变。(指定某个元素位置不变,如该题目就指定了元素0的位置不能改变,剩余元素进行排序)

Example:

except_zero([5, 3, 0, 0, 4, 1, 4, 0, 7]) == [1, 3, 0, 0, 4, 4, 5, 0, 7]

except_zero([0, 2, 3, 1, 0, 4, 5]) == [0, 1, 2, 3, 0, 4, 5]

 代码实现:

方法一:选择排序法

def except_zero(items):
    for i in range(0,len(items)-1):
        if items[i]==0:
            continue
        for j in range(i+1,len(items)):
            if items[j]==0:
                continue
            if items[i]>items[j]:
                items[i],items[j]=items[j],items[i]
    return items


if __name__ == '__main__':
    print("Example:")
    print(list(except_zero([5, 3, 0, 0, 4, 1, 4, 0, 7])))

    # These "asserts" are used for self-checking and not for an auto-testing
    assert list(except_zero([5, 3, 0, 0, 4, 1, 4, 0, 7])) == [1, 3, 0, 0, 4, 4, 5, 0, 7]
    assert list(except_zero([0, 2, 3, 1, 0, 4, 5])) == [0, 1, 2, 3, 0, 4, 5]
    assert list(except_zero([0, 0, 0, 1, 0])) == [0, 0, 0, 1, 0]
    assert list(except_zero([4, 5, 3, 1, 1])) == [1, 1, 3, 4, 5]
    assert list(except_zero([0, 0])) == [0, 0]
    print("Coding complete? Click 'Check' to earn cool rewards!")

方法二:删除指定元素衔接逻辑判断法

def except_zero(l):
    l1=sorted(t for t in l if t!=0)
    result=[]
    t=0
    for i in l:
        if i in l1:
            result.append(l1[t])
            t+=1
        else:
            result.append(0)
    return result

思路分析:

方法一比较直接明了,选择排序是从第一个数开始和它后面的数依次做比较,一直到倒数第二个数和倒数第一个数做比较。那么当外循环和内循环轮到了指定的元素0的时候,就直接continue跳过该循环不做位置上的变动即可。

方法二就是先得到一个不含有指定元素0的列表l1,然后通过for i in l遍历原来含有指定元素0的列表l,当元素i存在于l1列表中,说明该l列表中位置不是指定元素0,从而往result列表中加入l1的第1个元素,而当元素i不存在于l1列表中,说明l列表中该位置的元素是0,从而往result列表中添加元素0,当然你也可以不构建新列表result,直接用下标变量t和insert方法直接往l1中加入元素0即可。

Best Code:

def except_zero(L):
    s = iter(sorted(filter(None, L)))
    return [x and next(s) for x in L]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我的思路很明确

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值