【代码随想录python笔记整理】第十四课 · 链表的基础操作 2

**前言:**本笔记仅仅只是对内容的整理和自行消化,并不是完整内容,如有侵权,联系立删。

一、分析题目要求

在前面一课中,我们学习了链表的创建以及新元素的插入,并且我们学会了打印链表中的元素。这节课我们依托上节课的基础继续练习链表的操作。由于一些基础知识我们已经掌握,这节课我们首先来分析这道题目的要求再来作答。

针对以上问题,我们第一时间会发现主要部分其实和之前一课的链表练习差别不大,都需要首先构建一个链表,再向其中插入数据,最后按要求打印链表的元素。因此首先我们整体观察输入要求,这次不再是无限循环输入,因此不需要使用 try...except... 语句。

接着我们逐条看输入要求,发现总共有三行输入,第一行有两个数 n,k,分别代表第二行和第三行的元素个数。相应地,第二行和第三行就是想要输入到链表中的元素和我们需要打印出的元素位次。

然后我们去看输出的要求,这里有两个注意事项:1、每一个元素输出后要换行,再输出第二个数;2、对于位次超过了链表中含有节点个数的情况,我们要输出一行语句,告诉用户输入有问题。

二、根据分析结果分别实现相应任务

1、构建基本的链表框架:

python 复制代码
# 链表节点类
class Node:
    def __init__(self,data):
        self.data = data
        self.next = None
# 链表类
class LinkedList:
    def __init__(self):
        self.head_node = None
        self.length = 0
    def insert(self,data):
        self.length += 1
        new_node = Node(data)
        if self.head_node is None:
            self.head_node = new_node
            return self.head_node
        else:
            current_node = self,head_node
            while current_node.next is not None:
                current_node = current_node.next
            current_node.next = new_node
            return new_node

2、完成输入任务

python 复制代码
n,k = map(int,input().split())
# 新建链表实例
link_list = LinkedList()
elements = list(map(int,input().split()))
# 循环输入数据并存储到链表中
for data in elements:
    link_list.insert(data)
# 获取所需输出的链表位次
m_values = list(map(int, input().split()))

3、完成输出任务

python 复制代码
for m in m_values:
      # 如果 m 位置不合法
    if m < 1 or m > link_list.length:
        print("Output position out of bounds.")
    else:
          # 找到第 m 个节点
        current_node = link_list.headNode
        for _ in range(m - 1):
            current_node = current_node.next
        # 输出第 m 个节点的值
        print(current_node.data)

依托上面三部分,我们就完成了整个程序,但其实我们可以在类中再构建一个函数,专门用来输出第 m 个元素。

三、寻找第 n 个节点的方法

其实可以将寻找第 m 个节点和 insert 方法一样,定义为链表类的一个方法,方法需要接收一个参数。

python 复制代码
# get方法用于查找 第 n 个节点
def get(self, n):
      # 如果 n 小于 1 或者 大于链表的长度,返回 None
    if n < 1 or n > self.length:
        return None
    i = 1
    # 从头节点开始遍历
    current_node = self.head_node
    while current_node is not None:
        if i == n: #  i == n 的时候 找到第 n 个节点
            return current_node
        i += 1 # i 的值 + 1
        current_node = current_node.next # 移动 current_node指针,转为下一个节点
    # 没有找到第 n 个的节点的情况下,返回 None
    return None

然后在对应的位置调用 get 方法即可。

python 复制代码
m_values = list(map(int, input().split()))
for m in m_values:
    node = link_list.get(m) # 调用 get 方法,获取第 m 个节点
    if node is not None: # 如果节点 不为 None, 输出对应的 data
        print(node.data)
    else: # 否则,则为 m 位置不合法
        print("Output position out of bounds.")
相关推荐
Charles Ray29 分钟前
C++学习笔记 —— 内存分配 new
c++·笔记·学习
重生之我在20年代敲代码30 分钟前
strncpy函数的使用和模拟实现
c语言·开发语言·c++·经验分享·笔记
我要吐泡泡了哦1 小时前
GAMES104:15 游戏引擎的玩法系统基础-学习笔记
笔记·学习·游戏引擎
骑鱼过海的猫1231 小时前
【tomcat】tomcat学习笔记
笔记·学习·tomcat
waterHBO2 小时前
python 爬虫 selenium 笔记
爬虫·python·selenium
编程零零七3 小时前
Python数据分析工具(三):pymssql的用法
开发语言·前端·数据库·python·oracle·数据分析·pymssql
贾saisai4 小时前
Xilinx系FPGA学习笔记(九)DDR3学习
笔记·学习·fpga开发
北岛寒沫4 小时前
JavaScript(JS)学习笔记 1(简单介绍 注释和输入输出语句 变量 数据类型 运算符 流程控制 数组)
javascript·笔记·学习
烟雨666_java4 小时前
JDBC笔记
笔记
GEEKVIP4 小时前
Android 恢复挑战和解决方案:如何从 Android 设备恢复删除的文件
android·笔记·安全·macos·智能手机·电脑·笔记本电脑