IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> py.CheckiO刷题—O‘REILLY岛:Sort Except Zero -> 正文阅读

[数据结构与算法]py.CheckiO刷题—O‘REILLY岛:Sort Except Zero

题目背景:

对数组中的数字进行排序。但是零的位置不应该改变。(指定某个元素位置不变,如该题目就指定了元素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]

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-04-06 23:27:37  更:2022-04-06 23:29:10 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 4:19:51-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码