学习日志014--用python实现顺序表

news2024/11/22 22:03:25

之前我们用c语言实现顺序表,今天就然我们用python来复习一遍

一、创建顺序表

python的类可以代替c中的结构体作为复合数据类型。

创建学生类,并用装饰器将方法属性化,便于之后的修改。属性装饰器,可以在保护私有属性,可以便捷调用方法

class Student:
    def __init__(self,sid,name,score):
        self.__id = sid
        self.__s_name = name
        self.__score = score

    @property
    def s_name(self):
        return self.__s_name

    @s_name.setter
    def s_name(self,name):
        self.__s_name = name

    @property
    def id(self):
        return self.__id

    @id.setter
    def id(self, sid):
        self.__id = sid

    @property
    def score(self):
        return self.__score

创建顺序表类,并初始化

class SeqList:
    def __init__(self,capacity=10):
        self.size = 0
        self.capacity = capacity
        self.data = [None] * self.capacity

设置添加方法,将学生对象装入顺序表

# 插入元素
    def insert(self,value,sub):
        # 判断是否符合插入条件
        if self.is_full() or sub < 0 or sub > self.size:
            print("添加失败")
            return False
        else:
            i = 0
            while i<self.size-sub:
                self.data[self.size-i] = self.data[self.size-i-1]
                i += 1
            self.data[sub] = value
            self.size += 1

 删除指定元素

#删除元素
    def delete(self,sub):
        if self.is_empty() or sub < 0 or sub > self.size -1:
            print("删除失败")
            return False
        else:
            i = sub
            while i < self.size-1:
                self.data[i] = self.data[i+1]
                i += 1
            self.size -= 1
    # 遍历元素

根据学号查找

    # 按学号查找返回下标

    def find(self,s_id):
        if self.is_empty():
            print("查找失败")
            return -1
        else:
            i = 0
            while i<self.size:
                if self.data[i].id == s_id:
                    return i
                i += 1
            else:
                print("查找失败")
                return -1

遍历顺序表

    # 遍历元素

    def show(self):
        i = 0
        while i<self.size:
            print(self.data[i])
            i += 1

去重

    # 去重
    def ded(self):
        # 判断是否为空
        if self.is_empty():
            print("去重失败")
        else:
            i = 0
            # 循环遍历每一个元素
            while i<self.size-1:
                j = i + 1
                # 将元素与顺序表中其他元素比较
                while j<self.size:
                    if self.data[i].id == self.data[j].id:
                        # 调用删除函数删除数值相同的元素
                        self.delete(j)
                        # 删除后比较元素下标回退
                        continue
                    j += 1
                i += 1
            return

运行模块

    s1 = Student(1001, "小米", 98)
    s2 = Student(1002, "小红", 98)
    s3 = Student(1003, "小华", 98)
    s4 = Student(1004, "小路", 98)
    s5 = Student(1005, "小王", 98)
    s6 = Student(1001, "小米", 98)

    S = SeqList()

    S.insert(s1, 0)
    S.insert(s2, 1)
    S.insert(s3, 1)
    S.insert(s4, 1)
    S.insert(s5, 1)
    S.insert(s6, 1)
    S.show()
    a = S.find(1002)
    S.delete(a)
    S.show()
    S.ded()
    S.show()

类模块全部代码

 




class Student:
    def __init__(self,sid,name,score):
        self.__id = sid
        self.__s_name = name
        self.__score = score

    def __str__(self):
        return f"{self.s_name} {self.id} {self.score}"

    @property
    def s_name(self):
        return self.__s_name

    @s_name.setter
    def s_name(self,name):
        self.__s_name = name

    @property
    def id(self):
        return self.__id

    @id.setter
    def id(self, sid):
        self.__id = sid

    @property
    def score(self):
        return self.__score

    @score.setter
    def score(self, score):
        self.__score = score

class SeqList:
    def __init__(self,capacity=30):
        self.size = 0 # 设置顺序表元素个数,并初始化归零
        self.capacity = capacity # 置顺序表容量,默认为30
        self.data = [None] * self.capacity # 设置空顺序表

# 判断表满
    def is_full(self):
        return self.size == self.capacity

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

# 插入元素
    def insert(self,value,sub):
        # 判断是否符合插入条件
        if self.is_full() or sub < 0 or sub > self.size:
            print("添加失败")
            return False
        else:
            i = 0
            while i<self.size-sub:
                self.data[self.size-i] = self.data[self.size-i-1]
                i += 1
            self.data[sub] = value
            self.size += 1

#删除元素
    def delete(self,sub):
        if self.is_empty() or sub < 0 or sub > self.size -1:
            print("删除失败")
            return False
        else:
            i = sub
            while i < self.size-1:
                self.data[i] = self.data[i+1]
                i += 1
            self.size -= 1
    # 遍历元素

    def show(self):
        i = 0
        while i<self.size:
            print(self.data[i],end="")
            i += 1
        print()


    # 按学号查找返回下标

    def find(self,s_id):
        if self.is_empty():
            print("查找失败")
            return -1
        else:
            i = 0
            while i<self.size:
                if self.data[i].id == s_id:
                    return i
                i += 1
            else:
                print("查找失败")
                return -1
    # 去重
    def ded(self):
        # 判断是否为空
        if self.is_empty():
            print("去重失败")
        else:
            i = 0
            # 循环遍历每一个元素
            while i<self.size-1:
                j = i + 1
                # 将元素与顺序表中其他元素比较
                while j<self.size:
                    if self.data[i].id == self.data[j].id:
                        # 调用删除函数删除数值相同的元素
                        self.delete(j)
                        # 删除后比较元素下标回退
                        continue
                    j += 1
                i += 1
            return

if __name__ == '__main__':
    s1 = Student(1001, "小米", 98)
    s2 = Student(1002, "小红", 98)
    s3 = Student(1003, "小华", 98)
    s4 = Student(1004, "小路", 98)
    s5 = Student(1005, "小王", 98)
    s6 = Student(1001, "小米", 98)

    S = SeqList()

    S.insert(s1, 0)
    S.insert(s2, 1)
    S.insert(s3, 1)
    S.insert(s4, 1)
    S.insert(s5, 1)
    S.insert(s6, 1)
    S.show()
    a = S.find(1002)
    S.delete(a)
    S.show()
    S.ded()
    S.show()

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

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

相关文章

Docker搭建有UI的私有镜像仓库

Docker搭建有UI的私有镜像仓库 一、使用这个docker-compose.yml文件&#xff1a; version: 3services:registry-ui:image: joxit/docker-registry-ui:2.5.7-debianrestart: alwaysports:- 81:80environment:- SINGLE_REGISTRYtrue- REGISTRY_TITLEAtt Docker Registry UI- DE…

容器安全检测和渗透测试工具

《Java代码审计》http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247484219&idx1&sn73564e316a4c9794019f15dd6b3ba9f6&chksmc0e47a67f793f371e9f6a4fbc06e7929cb1480b7320fae34c32563307df3a28aca49d1a4addd&scene21#wechat_redirect Docker-bench-…

Day10_CSS过度动画

Day10_CSS过度动画 背景 : PC和APP项目我们已经开发完毕, 但是再真正开发的时候有些有些简易的动态效果我们可以使用CSS完成 ; 本节课我们来使用CSS完成基础的动画效果 今日学习目标 CSS3过度CSS3平面动态效果CSS3动画效果案例 1. CSS3过渡 ​ 含义 :过渡指的是元素从一种…

iOS应用网络安全之HTTPS

移动互联网开发中iOS应用的网络安全问题往往被大部分开发者忽略, iOS9和OS X 10.11开始Apple也默认提高了安全配置和要求. 本文以iOS平台App开发中对后台数据接口的安全通信进行解析和加固方法的分析. 1. HTTPS/SSL的基本原理 安全套接字层 (Secure Socket Layer, SSL) 是用来…

excel版数独游戏(已完成)

前段时间一个朋友帮那小孩解数独游戏&#xff0c;让我帮解&#xff0c;我看他用电子表格做&#xff0c;只能显示&#xff0c;不能显示重复&#xff0c;也没有协助解题功能&#xff0c;于是我说帮你做个电子表格版的“解题助手”吧&#xff0c;不能直接解题&#xff0c;但该有的…

金融数据中心容灾“大咖说” | 美创科技赋能“灾备一体化”建设

中国人民银行发布的《金融数据中心容灾建设指引》&#xff08;JR/T 0264—2024&#xff09;已于2024年7月29日正式实施。这一金融行业标准对金融数据中心容灾建设中的“组织保障、需求分析、体系规划、建设要求、运维管理”进行了规范和指导。面对不断增加的各类网络、业务、应…

Qt:信号槽

一. 信号槽概念 信号槽 是 Qt 框架中一种用于对象间通信的机制 。它通过让一个对象发出信号&#xff0c;另一个对象连接到这个信号的槽上来实现通信。信号槽机制是 Qt 的核心特性之一&#xff0c;提供了一种灵活且类型安全的方式来处理事件和数据传递。 1. 信号的本质 QT中&a…

SpringBoot与MongoDB深度整合及应用案例

SpringBoot与MongoDB深度整合及应用案例 在当今快速发展的软件开发领域&#xff0c;NoSQL数据库因其灵活性和可扩展性而变得越来越流行。MongoDB&#xff0c;作为一款领先的NoSQL数据库&#xff0c;以其文档导向的存储模型和强大的查询能力脱颖而出。本文将为您提供一个全方位…

大数据调度组件之Apache DolphinScheduler

Apache DolphinScheduler 是一个分布式易扩展的可视化 DAG 工作流任务调度系统。致力于解决数据处理流程中错综复杂的依赖关系&#xff0c;使调度系统在数据处理流程中开箱即用。 主要特性 易于部署&#xff0c;提供四种部署方式&#xff0c;包括Standalone、Cluster、Docker和…

ThinkPHP6门面(Facade)

门面 门面&#xff08;Facade&#xff09; 门面为容器中的&#xff08;动态&#xff09;类提供了一个静态调用接口&#xff0c;相比于传统的静态方法调用&#xff0c; 带来了更好的可测试性和扩展性&#xff0c;你可以为任何的非静态类库定义一个facade类。 系统已经为大部分…

MySQL win安装 和 pymysql使用示例

目录 一、MySQL安装 下载压缩包&#xff1a; 编写配置文件&#xff1a; 配置环境变量&#xff1a; 初始化服务和账户 关闭mysql开机自启&#xff08;可选&#xff09; 建议找一个数据库可视化软件 二、使用pymysql操作数据库 安装pymysql 示例代码 报错处理 一、My…

Parker派克防爆电机在实际应用中的安全性能如何保证?

Parker防爆电机确保在实际应用中的安全性能主要通过以下几个方面来保证&#xff1a; 1.防爆外壳设计&#xff1a;EX系列电机采用强大的防爆外壳&#xff0c;设计遵循严格的防爆标准&#xff0c;能够承受内部可能发生的爆炸而不破损&#xff0c;利用间隙切断原理&#xff0c;防…

空间与单细胞转录组学的整合定位肾损伤中上皮细胞与免疫细胞的相互作用

result 在空间转录组图谱中对人类肾脏进行无监督映射和细胞类型鉴定 我们试图在H&E染色的人类参考肾切除标本组织切片上直接映射转录组特征。该组织来自一名59岁的女性&#xff0c;其肾小球闭塞和间质纤维化程度最低&#xff08;分别影响不到10%的肾小球或肾实质&#xff…

greater<>() 、less<>()及运算符 < 重载在排序和堆中的使用

简略图 greater<>()(a, b) a > b 返回true&#xff0c;反之返回false less<>()(a, b) a < b 返回true&#xff0c;反之返回false 在cmp中使用&#xff08;正着理解&#xff09; 规则返回true时a在前&#xff0c;反之b在前 在priority_queue中使用 &#xff…

详细描述一下Elasticsearch索引文档的过程?

大家好&#xff0c;我是锋哥。今天分享关于【详细描述一下Elasticsearch索引文档的过程&#xff1f;】面试题。希望对大家有帮助&#xff1b; 详细描述一下Elasticsearch索引文档的过程&#xff1f; Elasticsearch的索引文档过程是其核心功能之一&#xff0c;涉及将数据存储到…

入门车载以太网(6) -- XCP on Ethernet

目录 1.寻址方式 2.数据帧格式 3.特殊指令 4.使用实例 了解了SOME/IP之后&#xff0c;继续来看看车载以太网在汽车标定领域的应用。 在汽车标定领域XCP是非常重要的协议&#xff0c;咱们先来回顾下基础概念。 XCP全称Universal Measurement and Calibration Protocol&a…

Python中常用的函数介绍

Python中常用的几种函数 1、input函数 input()函数&#xff1a;主要作用是让用户输入某个内容并接收它。 #输入你的年龄 >>> age input("my age is :") my age is :20 执行代码后输入年龄&#xff0c;年龄被存放到age变量中&#xff0c;执行print后终端会…

Ubuntu从入门到精通(二)远程和镜像源配置齐全

Ubuntu从入门到精通(二) 1 常见操作配置 1.1 英文语言配置 1.1.1 打开设置 1.1.2 设置语言为英文 1.1.3 重启生效 1.1.4 再次进入,选择更新名字 1.1.5 再次进入,发现已经变成了英文 1.2 输入法配置 1.3 rustdesk安装 1.3.1 Windows系统配置 登陆:https://github.com…

卷积神经网络(CNN)中的池化层(Pooling Layer)

池化层&#xff08;Pooling Layer&#xff09;&#xff0c;也被称为下采样层&#xff0c;是深度学习神经网络中常用的一种层级结构。它通常紧跟在卷积层之后&#xff0c;对卷积层输出的特征图进行下采样操作。 一、定义与功能 池化层的主要作用是通过减少特征图的尺寸来降低计算…

【linux硬件操作系统】计算机硬件常见硬件故障处理

这里写目录标题 一、故障排错的基本原则二、硬件维护注意事项三、关于最小化和还原出厂配置四、常见故障处理及调试五、硬盘相关故障六、硬盘相关故障&#xff1a;硬盘检测问题七、硬盘相关故障&#xff1a;自检硬盘报错八、硬盘相关故障&#xff1a;硬盘亮红灯九、硬盘相关故障…