python之顺序存储结构

本文介绍了如何使用Python创建一个顺序存储结构的类SeqList,包括初始化、检查是否为空、是否已满、获取和设置元素、查找元素、计数、清空、插入、删除以及输出列表内容等操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#-*- coding utf-8 -*-
__author__="clearlove"
class SeqList(object):#创建8个元素大小的列表
    def __init__(self,max=10):
        self.max=max  #创建默认为8
        self.num=0
        self.date=[None]*self.max
    def is_empty(self):
        return self.num is 0
    def is_full(self):
        return self.num is self.max
    def __getitem__(self,key):#获取某个位置的元素
        if not isinstance(key,int):
            raise TypeError
        if 0<=key<self.num:
            return self.date[key]
        else:
            raise IndexError
    def __setitem__(self,key,value):#设置某个位置的元素
        if not isinstance(key,int):
            raise TypeError
        if 0<=key<self.num:
            self.date[key]=value
        else:
            raise IndexError
    def index(self,value):
        for j in range(self.num):
            if self.date[j]==value:
                return j
        if j==self.num:
            return -1
        raise ValueError
    def count(self):
        return self.num
    def clear(self):
        self.__init__()
    def __len__(self):
        return self.num
    def append(self,value):#末尾插入操作
        if self.is_full():
            print ("The list is full")
            return
        else:
            self.date[self.num]=value
            self.num+=1
    def insert(self,key,value):#插入任意位置  
        if not isinstance(key,int):
            raise TypeError
        if key<0 or key>self.num:
            raise IndexError
        for j in range(self.num,key,-1):
            self.date[j]=self.date[j-1]
        self.date[key]=value
        self.num+=1
    def remove(self,key):
        if not isinstance(key,int):
            raise TypeError
        if key<0 or key>self.num:
            raise IndexError
        for j in range(key,self.num):
            self.date[j]=self.date[j+1]
        self.num-=1
    #输出操作
    def printList(self):
        for i in range(0,self.num):
            print (self.date[i])
    #清除操作
    def clear(self):
        self.__init__()
if __name__=="__main__":
    a=SeqList()
    print(a.date)
    #num=0
    print(a.is_empty())
    a.append(0)
    a.append(1)
    a.append(2)
    print (a.date)
    print (a.num)
    print (a.max)
    a.insert(1,6)
    print (a.date)
    a.append(8)
    print (a.date)
    a.printList()
    a.clear()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值