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

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

一、分析题目要求

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

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

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

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

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

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

# 链表节点类
class Node:def __init__(self,data):self.data = dataself.next = None
# 链表类
class LinkedList:def __init__(self):self.head_node = Noneself.length = 0def insert(self,data):self.length += 1new_node = Node(data)if self.head_node is None:self.head_node = new_nodereturn self.head_nodeelse:current_node = self,head_nodewhile current_node.next is not None:current_node = current_node.nextcurrent_node.next = new_nodereturn new_node

2、完成输入任务

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、完成输出任务

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.headNodefor _ in range(m - 1):current_node = current_node.next# 输出第 m 个节点的值print(current_node.data)

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

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

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

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

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

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, 输出对应的 dataprint(node.data)else: # 否则,则为 m 位置不合法print("Output position out of bounds.")

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【论文精读】LLaMA1

摘要 以往的LLM&#xff08;Large Languages Models&#xff09;研究都遵从一个假设&#xff0c;即更多的参数将导致更好的性能。但也发现&#xff0c;给定计算预算限制后&#xff0c;最佳性能的模型不是参数最大的&#xff0c;而是数据更多的。对于实际场景&#xff0c;首选的…

IT行业风向让人琢磨不透,一端狂裁,一端狂吸收……

2024年伊始&#xff0c;全球科技行业显然又掀起了新一波的裁员潮。尽管这轮裁员潮来得不如去年年初那样猛烈&#xff0c;但依然不免令不少人感到措手不及…… 甚至有人开工第一天收到的并不是开门红包&#xff0c;而是裁员说明书&#xff1a; 以前一直以为年前被裁&#xff0c;…

PureFlash v1.9.1特性介绍

PureFlashv1.9.1版本特性主要有3个&#xff1a; 1. 支持RDMA网络 使用RDMA协议可以大大减少对CPU的消耗&#xff0c;性能提升30%以上。 PureFlash的网络配置分为存储节点间网络&#xff08;存储后端网&#xff09;和客户端网络&#xff08;前端网&#xff09;。都支持使用RD…

路坦利集群虚拟机断网处理方法

路坦利集群虚拟机断网处理方法 问题描述&#xff1a; 在路坦利集群中&#xff0c;虚拟机时不时断网&#xff0c;导致业务中断&#xff0c;临时解决办法为新增网卡配置相同IP&#xff0c;然后禁用旧网卡网络临时恢复。 注&#xff1a; 该配置必须让虚拟化平台上层交换机和宿…

LASSO算法

LASSO (Least Absolute Shrinkage and Selection Operator) 是一种回归分析的方法&#xff0c;它能够同时进行变量选择和正则化&#xff0c;以增强预测准确性和模型的解释性。LASSO通过在损失函数中加入一个L1惩罚项来实现这一点。该惩罚项对系数的绝对值进行约束。 基本概念 …

022 基于Spring Boot的校园二手交易平台(源码+数据库+10000字论文)

部分代码地址&#xff1a; https://github.com/XinChennn/xc022-Used-Trading-Platform2 基于Spring Boot的校园二手交易平台&#xff08;源码数据库10000字论文&#xff09; 一、系统介绍 基于Spring Boot的校园二手交易网站&#xff0c;方便学生处理自己的旧物&#xff0c…

springboot220基于SpringBoot+Vue的周边游平台个人管理模块的设计与实现

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考。 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项目编号&…

基于Java+SSM+Jsp宿舍管理系统(源码+演示视频+包运行成功)

您好&#xff0c;我是码农小波&#xff08;wei158888&#xff09;&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 ❤️ 1. 毕业设计专栏&#xff0c;毕业季咱们不慌&#xff0c;上千款毕业设计等你来选。 目录 1、项目背景 2、项目演示 3、使用技术 4、系统设计 …

Windows系统安全策略设置之本地NTLM重放提权

经安全部门研究分析&#xff0c;近期利用NTLM重放机制入侵Windows 系统事件增多&#xff0c;入侵者主要通过Potato程序攻击拥有SYSTEM权限的端口伪造网络身份认证过程&#xff0c;利用NTLM重放机制骗取SYSTEM身份令牌&#xff0c;最终取得系统权限&#xff0c;该安全风险微软并…

Flask——基于python完整实现客户端和服务器后端流式请求及响应

文章目录 本地客户端Flask服务器后端客户端/服务器端流式接收[打字机]效果 看了很多相关博客&#xff0c;但是都没有本地客户端和服务器后端的完整代码示例&#xff0c;有的也只说了如何流式获取后端结果&#xff0c;基本没有讲两端如何同时实现流式输入输出&#xff0c;特此整…

Atcoder ABC341 D - Only one of two

Only one of two&#xff08;只有两个中的一个&#xff09; 时间限制&#xff1a;2s 内存限制&#xff1a;1024MB 【原题地址】 所有图片源自Atcoder&#xff0c;题目译文源自脚本Atcoder Better! 点击此处跳转至原题 【问题描述】 【输入格式】 【输出格式】 【样例1】 …

蓝桥杯-扫雷

代码解答及思路: #include <iostream> using namespace std; int main() { int n,m; int a[100][100] {0},b[100][100];//记住要开数组确数 &#xff0c;这样外围就会有边 &#xff0c;不能直接设置值&#xff0c;要记住&#xff01;&#xff01;&#xff01;&#…