py数据结构day3

news2025/4/9 15:54:53

思维导图:

代码1(完成双向循环链表的判空、尾插、遍历、尾删):

class Node:
    def __init__(self, data):
        self.data = data
        self.next = None
        self.prev = None

class DoubleCycleLink:
    def __init__(self):
        self.head = None
        self.tail = None
        self.size = 0

    #判空
    def is_empty(self):
        return self.size == 0

    #尾插
    def add_tail(self, data):
        node = Node(data)
        if self.is_empty():
            self.head = node
            self.tail = node
            node.next = self.head
            node.prev = self.tail
            self.size += 1
        else:
            node.prev = self.tail
            node.next = self.head
            self.tail.next = node
            self.tail = node
            self.head.prev = self.tail
            self.size += 1

    #遍历
    def show(self):
        if self.is_empty():
            print("空链表")
        else:
            q = self.head
            while q != self.tail:
                print(q.data, end=" ")
                q = q.next
            print(q.data)

    #尾删
    def delete_tail(self):
        if self.is_empty():
            print("空链表")
        else:
            self.tail = self.tail.prev
            self.tail.next = self.head
            self.head.prev = self.tail
            self.size -= 1

if __name__ == "__main__":
    link = DoubleCycleLink()
    link.add_tail(10)
    link.add_tail(20)
    link.add_tail(30)
    link.add_tail(40)
    link.add_tail(50)
    link.show()
    print("=============================")
    link.delete_tail()
    link.show()

代码2(不使用内置函数的情况下,完成顺序栈的创建栈、判空、入栈、出栈、获取栈顶元素、求栈的大小、遍历栈):
 

# 不使用内置函数实现顺序栈
class Stack:
    def __init__(self, capacity=10):
        self.capacity = capacity
        self.top = -1
        self.data = [None] * capacity
        self.size = 0

    # 入栈
    def push(self, data):
        if self.top == self.capacity - 1:
            print("栈已满")
            return
        self.top += 1
        self.data[self.top] = data
        self.size += 1

    # 遍历
    def show(self):
        for i in range(self.top, -1, -1):
            print(self.data[i], end=" ")
        print()

    # 出栈
    def pop(self):
        if self.top == -1:
            print("栈已空")
            return
        self.top -= 1
        self.size -= 1

    # 获取栈顶元素
    def top(self):
        if self.top == -1:
            print("栈已空")
            return
        return self.data[self.top]

    # 获取栈大小
    def size(self):
        return self.size


if __name__ == '__main__':
    stack = Stack()
    for i in range(10):
        stack.push(i)

    stack.show()
    stack.pop()
    stack.show()
    print(stack.top)
    print(stack.size)

代码3(不使用内置函数的情况下,完成链式栈的创建栈、判空、入栈、出栈、获取栈顶元素、求栈的大小、遍历栈):

#不使用内置函数实现链式栈
# 普通节点
class Node:
    def __init__(self, data):
        self.data = data
        self.next = None


# 带头节点的单向链表
class LinkList:
    def __init__(self, node=None):
        self.size = 0  # 链表长度
        self.head = node  # 头结点

    # 判空
    def is_empty(self):
        # return self.head is None
        return self.size == 0

    # 头插
    def add_head(self, data):
        node = Node(data)
        if self.is_empty():
            self.head = node
            self.size += 1
        else:
            node.next = self.head
            self.head = node
            self.size += 1

    # 遍历
    def show(self):
        if self.is_empty():
            print("空链表")
        else:
            p = self.head
            while p:
                print(p.data, end=" ")
                p = p.next
            print()

    # 头删
    def delete_head(self):
        if self.is_empty():
            print("空链表")
        else:
            self.head = self.head.next
            self.size -= 1

    #获取栈顶元素
    def top(self):
        if self.is_empty():
            print("空链表")
        else:
            return self.head.data

    #获取栈的长度
    def size(self):
        return self.size






if __name__ == '__main__':
    # 构造一个单向链表
    link = LinkList()
    link.add_head(1)
    link.add_head(3)
    link.add_head(5)
    link.add_head(4)
    link.add_head(7)
    link.add_head(9)
    link.show()
    print("=============================")
    link.delete_head()  # 头删
    link.show()
    print("=============================")
    num = link.top()  # 获取栈顶元素
    print(f"栈顶元素为{num}")
    print("=============================")
    length = link.size  # 获取栈的长度
    print(f"栈的长度为{length}")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2327342.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

STM32单片机入门学习——第8节: [3-4] 按键控制LED光敏传感器控制蜂鸣器

写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难,但我还是想去做! 本文写于:2025.04.02 STM32开发板学习——第8节: [3-4] 按键控制LED&光敏传感器控制蜂鸣器 前言开…

【JavaScript】十三、事件监听与事件类型

文章目录 1、事件监听1.1 案例:击关闭顶部广告1.2 案例:随机点名1.3 事件监听的版本 2、事件类型2.1 鼠标事件2.1.1 语法2.1.2 案例:轮播图主动切换 2.2 焦点事件2.2.1 语法2.2.2 案例:模拟小米搜索框 2.3 键盘事件2.3.1 语法2.3.…

通过ansible+docker-compose快速安装一主两从redis+三sentinel

目录 示例主机列表 架构参考 文件内容 安装脚本 ansible变量,需修改 ansible配置文件和主机清单,需修改 运行方式 验证故障转移master 涉及redis镜像和完整的脚本文件 示例主机列表 架构参考 文件内容 安装脚本 #!/bin/bashset -e export pa…

mysql docker容器启动遇到的问题整理

好几个月没折腾mysql的部署,弄了下,又遇到不少问题 问题一:Access denied for user ‘root‘‘172.18.0.1‘ docker容器启动后,本地navicat 连接报这个错误 查到两个方案,一个貌似是要让root用户能在任意ip地址&…

长短期记忆神经网络(LSTM)基础学习与实例:预测序列的未来

目录 1. 前言 2. LSTM的基本原理 2.1 LSTM基本结构 2.2 LSTM的计算过程 3. LSTM实例:预测序列的未来 3.1 数据准备 3.2 模型构建 3.3 模型训练 3.4 模型预测 3.5 完整程序预测序列的未来 4. 总结 1. 前言 在深度学习领域,循环神经网络&…

C++多继承

可以用多个基类来派生一个类。 格式为: class 类名:类名1,…, 类名n { private: … ; //私有成员说明; public: … ; //公有成员说明; protected: … ; //保护的成员说明; }; class D: public A, protected B, private C { …//派…

【深度学习新浪潮】DeepSeek近期的技术进展及未来动向

一、近期技术进展 模型迭代与性能提升 DeepSeek-V3-0324版本更新:2025年3月24日发布,作为V3的小版本升级,参数规模达6850亿,采用混合专家(MoE)架构,激活参数370亿。其代码能力接近Claude 3.7,数学推理能力显著提升,且在开源社区(如Hugging Face)上线。DeepSeek-R1模…

工业4.0时代下的人工智能新发展

摘要:随着德国工业4.0时代以及中国制造2025的提出,工业智能化的改革的时代正逐渐到来,然而我国整体工业水平仍然处于工业2.0水平。围绕工业4.0中智能工厂、智能生产、智能物流这三大主题,结合国内外研究现状,对人工智能…

监控易一体化运维:高性能与易扩展,赋能运维新高度

在当今数字化时代,云技术、大数据、智慧城市等前沿科技蓬勃发展,企业和城市对 IT 基础设施的依赖程度与日俱增。在这样的大环境下,运维系统的高性能与易扩展性对于保障业务稳定运行和推动发展的关键意义。今天,为大家深入剖析监控…

机器学习stats_linregress

import numpy as np from scipy import stats# r stats.linregress(xs, ys) 是一个用于执行简单线性回归的函数,通常来自 scipy.stats 库。# 具体含义如下:# stats.linregress:执行线性回归分析,拟合一条最佳直线来描述两个变量 …

Linux系统01---指令

目录 学习的方法 Linux 系统介绍 2.1 Unix 操作系统(了解) 2.2 Linux 操作系统(了解) 2.3 Linux 操作系统的主要特性(重点) 2.4 Linux 与 Unix 的区别与联系 2.5 GUN 与 GPL(了解&#…

【蓝桥杯14天冲刺课题单】Day 8

1.题目链接:19714 数字诗意 这道题是一道数学题。 先考虑奇数,已知奇数都可以表示为两个相邻的数字之和,2k1k(k1) ,那么所有的奇数都不会被计入。 那么就需要考虑偶数什么情况需要被统计。根据打表,其实可以发现除了…

DeepSeek 开源的 3FS 如何?

DeepSeek 3FS(Fire-Flyer File System)是一款由深度求索(DeepSeek)于2025年2月28日开源的高性能并行文件系统,专为人工智能训练和推理任务设计。以下从多个维度详细解析其核心特性、技术架构、应用场景及行业影响&…

通过 Docker Swarm 集群探究 Overlay 网络跨主机通信原理

什么是Overlay网络, 用于解决什么问题 ? Overlay网络通过在现有网络之上创建一个虚拟网络层, 解决不同主机的容器之间相互通信的问题 如果没有Overlay网络,实现跨主机的容器通信通常需要以下方法: 端口映射使用宿主机网络模式 这些方法牺牲了容器网络…

HarmonyOS NEXT开发进阶(十四):HarmonyOS应用开发者基础认证试题集汇总及答案解析

文章目录 一、前言二、判断题(134道)三、单选题(210道)四、多选题(123道)五、拓展阅读 一、前言 鸿蒙原生技能学习阶段,通过官方认证的资格十分有必要,在项目实战前掌握基础开发理论…

MSVC编译遇到C2059、C2143、C2059、C2365、C2059等错误的解决方案

MSVC编译时,遇到如下错误: c:\program files (x86)\windows kits\10\include\10.0.18362.0\um\msxml.h(1842): error C2059: 语法错误:“常数” [D:\jenkins_home\workspace\xxx.vcxproj] c:\program files (x86)\windows kits\10\include\10.0.18362.0…

AI重塑云基础设施,亚马逊云科技打造AI定制版IaaS“样板房”

AI正在彻底重塑云基础设施。 IDC最新《2025年IDC MarketScape:全球公有云基础设施即服务(IaaS)报告》显示,AI正在通过多种方式重塑云基础设施,公有云IaaS有望继续保持快速增长,预计2025年全球IaaS的整体规…

Linux系统之systemctl管理服务及编译安装配置文件安装实现systemctl管理服务

目录 一.systemctl 管理服务 1.systemctl管理 2.设置服务卡机自启动或开机不启动 二.编译安装配置文件编写使得可以使用systemctl管理 1、编写配置文件原因 2、添加配置文件实现systemctl管理服务 一.systemctl 管理服务 1.systemctl管理 基本格式: systemc…

【NLP 52、多模态相关知识】

生活应该是美好而温柔的,你也是 —— 25.4.1 一、模态 modalities 常见: 文本、图像、音频、视频、表格数据等 罕见: 3D模型、图数据、气味、神经信号等 二、多模态 1、Input and output are of different modalities (eg: tex…

Element Plus 常用组件

2025/4/1 向全栈工程师迈进!!! 常见Element Plus组件的使用,其文章中“本次我使用到的按钮如下”是我自己做项目时候用到的,记录以加强记忆。阅读时可以跳过。 一、Button按钮 1.1基础按钮 在element plus中提供的按…