当前位置: 首页 > news >正文

求线性表的倒数第K项 (数组、头插法、尾插法)

给定一系列正整数,请设计一个尽可能高效的算法,查找倒数第K个位置上的数字。

输入格式:

输入首先给出一个正整数K,随后是若干非负整数,最后以一个负整数表示结尾(该负数不算在序列内,不要处理)。

输出格式:

输出倒数第K个位置上的数据。如果这个位置不存在,输出错误信息NULL

输入样例:

4 1 2 3 4 5 6 7 8 9 0 -1

题目解析:

 首先看到这道题目,作为一个线性表,我们要知道,典型的线性表有两种结构,分别是顺序表,和链表    ,我们就用这两种表,完成这一道题目

顺序表实现:

所谓顺序表,就是我们熟知的数组,这一道题目,他要求一段序列中的倒数第k个序列,那我们就只需要开一个vector数组,然后最后输出就好,非常的简单

//数组
vector<int > a;int x;while(cin>>x&&x>-1){a.push_back(x);}if(n>a.size()||n<1) cout<<"NULL";else  cout<<a[a.size()-n];
}
链表实现:

链表的初始化中,有两种非常典型的方法,分别是头插法和尾插法,那我们就带大家复习一个头插法和尾插法

尾插法:

尾插法,就是把给定的一段序列,把这段序列按照顺序依次插入链表当中 ,就是每次把要插入的内容插入链表的尾部,但是这道题目当中,我们为了输出倒数的元素,我们就可以设置一个pre指针指向前一个元素

 ①:初始化要插入的节点p

②:把p插入到链的尾 (r->next = p),p的pre指向p(p->pre = r

③:把链的尾调整到p (r=p)

过程大致如下:

代码实现:

//尾插法node *head = new node;head->next = NULL;int cnt = 0;head->pre = NULL;node *r = head,*p;int x;while(cin>>x&&x!=-1){p = new node;p->data = x;p->pre = r;p->next = NULL;r->next = p;r = p;cnt++;}

插入的结束之后,我们在插入的过程中使用了一个cnt来判断链表中的有效元素,来判断要输出的内容是否合法 。假设输出合法,因为这时候我们需要输出倒数第n个元素,因为时候我们的r或者p指针指向的是链表当中尾部,我们就只要需要利用p(r)的pre指针往回遍历即可

if(n>cnt||n<=0) cout<<"NULL";else {for(int i = 1;i<n;i++){p = p->pre;}cout<<p->data;}

头插法:

头插法,就是把给的一段序列,按照这一段序列的逆序,插入链表当中,就是把这一段序列,每一个元素插入的时候都都是他的的头部元素

①:初始化要插入的节点p

②:把p的next指向头部元素  (p->next = r)

③:把头部元素修改为p(r=p)

④:把p插入头结点之后(head->next = p)

代码实现:

//头插法  int x;node *p,*r;r = NULL;while(cin>>x&&x>=-0) {p = new node;p->data = x;p->next = r;r= p;head->next = r;cnt++;}

插入的结束之后,这时候我们只需要正向遍历,就可以找到我们想找到原来序列的倒数第n个元素

    if(n>cnt||n<=0) cout<<"NULL";else {for(int i = 1;i<n;i++) r = r->next;cout<<r->data;}

全部代码实现:

#include<bits/stdc++.h>
using namespace std;
typedef struct node{int data;struct node *next,*pre;
}node;
int main()
{int n;cin>>n;node *head = new node;head->next = NULL;int cnt = 0;head->pre = NULL;node *r = head,*p;int x;while(cin>>x&&x>=0){p = new node;p->data = x;p->pre = r;p->next = NULL;r->next = p;r = p;cnt++;}if(n>cnt||n<=0) cout<<"NULL";else {for(int i = 1;i<n;i++){p = p->pre;}cout<<p->data;}
}// 头插法  
// 	int x;
// 	node *p,*r;
// 	r = NULL;// 	while(cin>>x&&x>=-0) {// 		p = new node;
// 		p->data = x;
// 		p->next = r;
// 		r= p;
// 		head->next = r;
//         cnt++;
// 	}//   if(n>cnt||n<=0) cout<<"NULL";// else {for(int i = 1;i<n;i++) //    r = r->next;//    cout<<r->data;}// }// //数组:
// vector<int > a;
// 	 int x;
// 	 while(cin>>x&&x>-1){// 	 	a.push_back(x);
// 	 }
//     if(n>a.size()||n<1) cout<<"NULL";
// 	else  cout<<a[a.size()-n];
// }

最后测试点全部通过:

总结:

通过这个题目,重新巩固和熟悉了链表的头擦尾插的区别,并通过他们的区别来灵活写题,并且在运用链表的过程中,如果需要,我们可以把单链表变成双链表、循环链表等等形式,来进行对问题的解决

相关文章:

求线性表的倒数第K项 (数组、头插法、尾插法)

给定一系列正整数&#xff0c;请设计一个尽可能高效的算法&#xff0c;查找倒数第K个位置上的数字。 输入格式: 输入首先给出一个正整数K&#xff0c;随后是若干非负整数&#xff0c;最后以一个负整数表示结尾&#xff08;该负数不算在序列内&#xff0c;不要处理&#xff09…...

rustdesk自建服务器怎么填写客户端配置信息

目录 # id、api、中继都怎么填&#xff1f;rustdesk程序启动后服务不自动启动 # id、api、中继都怎么填&#xff1f; rustdesk程序启动后服务不自动启动 完全退出RudtDesk程序&#xff08;右下角托盘区有的话&#xff0c;需要右键点退出&#xff09; 创建windows服务&#xff…...

4月8日日记

今天抖音刷到一个视频 记了一下笔记 想做自媒体&#xff0c;直播&#xff0c;抖音是最大的平台&#xff0c;但是我的号之前因为跟人互喷被封号了 今天想把实名认证转移到新号上&#xff0c;试了一下竟然这次成功了&#xff0c;本以为能开直播了但是 还是因为之前的号有违规记…...

VScode添加python解释器

先安装python扩展 然后点ctrlshiftp搜索python:select&#xff0c;选择解析器&#xff08;或者也可以直接点左下方的&#xff09;...

Elasticsearch | ES索引模板、索引和索引别名的创建与管理

关注&#xff1a;CodingTechWork 引言 在使用 Elasticsearch (ES) 和 Kibana 构建数据存储和分析系统时&#xff0c;索引模板、索引和索引别名的管理是关键步骤。本文将详细介绍如何通过 RESTful API 和 Kibana Dev Tools 创建索引模板、索引以及索引别名&#xff0c;并提供具…...

用 Python 造轮子:打造轻量级 HTTP 调试工具

目录 一、为什么需要自建工具&#xff1f; 二、核心功能设计 三、技术选型 四、分步实现 第一步&#xff1a;搭建基础框架 第二步&#xff1a;实现请求转发逻辑 第三步&#xff1a;响应格式化处理 第四步&#xff1a;历史记录存储 五、进阶优化技巧 六、使用示例 七…...

java设计模式-原型模式

原型模式 1、原型模式(Prototype模式)是指&#xff1a;用原型实例指定创建对象的种类&#xff0c;并通过拷贝这些原型&#xff0c;创建新的对象 2、原型模式是一种创见性设计模式&#xff0c;允许一个对象再创建另一个可定制的对象&#xff0c;无需知道如何创建的细节。 3、工作…...

【Java设计模式】第9章 原型模式讲解

9. 原型模式 9.1 原型模式讲解 定义:通过拷贝原型实例创建新对象,无需调用构造函数。特点: 创建型模式无需了解创建细节适用场景: 类初始化消耗资源多对象创建过程繁琐(如属性赋值复杂)循环体中需创建大量对象优点: 性能优于直接new简化创建流程缺点: 必须实现clone()…...

Python 快速搭建一个小型的小行星轨道预测模型 Demo

目录 ✅ Demo 目标&#xff1a; &#x1f9ea; 模型方案选择 方案 1&#xff1a;开普勒 LSTM 混合预测&#xff08;推荐 &#x1f4a1;&#xff09; 方案 2&#xff1a;全 AI&#xff1a;LSTM 直接拟合轨迹 &#x1f6a7; 环境准备 &#x1f527; 示例代码结构&#xff…...

【AI】Ragflow构建本地知识库

https://github.com/infiniflow/ragflow/blob/main/README_zh.md DeepSeek搭建的本地知识库很呆&#xff1f;不符合自己的预期&#xff1f;看完这个视频你就明白了&#xff01;这样部署吊打其他的本地部署&#xff01;跟着教程来&#xff0c;不怕学不会&#xff01;_哔哩哔哩_…...

【Django】教程-12-柱状图

【Django】教程-1-安装创建项目目录结构介绍 【Django】教程-2-前端-目录结构介绍 【Django】教程-3-数据库相关介绍 【Django】教程-4-一个增删改查的Demo 【Django】教程-5-ModelForm增删改查规则校验【正则钩子函数】 【Django】教程-6-搜索框-条件查询前后端 【Django】教程…...

市政消防栓智能监控管理系统(Axure高保真原型)

在城市的运转体系中&#xff0c;市政消防栓扮演着无可替代的关键角色&#xff0c;作为城市公共安全基础设施的核心&#xff0c;它是火灾扑救时的关键水源保障&#xff0c;其重要性不言而喻。当火灾这头 “猛兽” 突然来袭&#xff0c;市政消防栓就是那道阻止火势蔓延、守护生命…...

机器学习课堂6交叉熵代价函数的逻辑回归模型

代码 # 2-10交叉熵代价函数的逻辑回归模型 import pandas as pd import numpy as np import matplotlib.pyplot as plt# 参数设置 iterations 1000 # 迭代次数 learning_rate 0.1 # 学习率 m_train 250 # 训练样本数量# 读入酒驾检测数据集 df pd.read_csv(alcohol_d…...

华为ar1200修改con口密码

<Huawei> <Huawei>sys Enter system view, return user view with CtrlZ. [Huawei]user-interface console 0 进入端口 [Huawei-ui-console0]authentication-mode pass 以pass模式登录 [Huawei-ui-console0]set authentication password cipher …...

Java 集合有序性与重复性总结及记忆技巧

Java 集合有序性与重复性总结及记忆技巧 一、集合分类速查表 集合类型是否有序是否允许重复记忆口诀ArrayList✅ 有序&#xff08;插入顺序&#xff09;✅ 可重复"数组列表&#xff0c;顺序记牢"LinkedList✅ 有序&#xff08;插入顺序&#xff09;✅ 可重复"…...

机器学习--词向量转换

引言 在自然语言处理&#xff08;NLP&#xff09;的广阔领域中&#xff0c;计算机面临的一大挑战是理解人类语言的丰富性和复杂性。文本数据对于机器而言&#xff0c;最初只是一连串难以理解的字符。词向量转换便成为了一座关键的桥梁&#xff0c;它将文本中的单词映射为数值向…...

时序数据异常检测-综述

更新中 异常检测基本概念 广义的Out-of-Distribution(广义的OOD)来描述异常检测的相关问题。OOD包括五个相关的子领域,分别为Anomaly Detection(AD)、Novelty Detection(ND)、Open Set Recogntion(OSR)、Out-of-Distribution(OOD)和Outlier Detection(OD)。这5个…...

2025年Python的主要应用场景

李升伟 编译 Python在2025年仍是最受欢迎和强大的编程语言之一。其简洁易读的语法以及庞大的库生态系统&#xff0c;使其成为各行业开发者的首选。无论是构建复杂的数据管道&#xff0c;还是自动化重复性任务&#xff0c;Python都能提供广泛的应用场景&#xff0c;以实现快速、…...

树的深度遍历和广度遍历

目录 一、深度优先遍历&#xff08;递归&#xff09;二叉树的深度优先遍历&#xff08;递归&#xff09; 二、广度优先遍历二叉树的广度遍历 一、深度优先遍历&#xff08;递归&#xff09; #include<iostream> #include<vector>using namespace std;const int N1…...

C++函数如何返回多个参数

在编程中&#xff0c;我们经常会遇到需要函数返回多个值的场景。虽然 C 函数不能直接返回多个参数&#xff0c;但通过一些间接的方法&#xff0c;我们可以轻松实现这一需求。本文将详细介绍几种常见的实现方式&#xff0c;并分析它们的优缺点和适用场景。 1. 引言 在 C 中&…...

Python 实现的运筹优化系统代码详解(0-1规划指派问题)

一、引言 在数学建模的广阔领域中&#xff0c;指派问题作为一类经典且重要的组合优化问题&#xff0c;频繁出现在各类实际场景里。例如&#xff0c;在人力资源管理中&#xff0c;如何将不同技能水平的员工高效地分配到各个项目&#xff0c;以实现项目成本最小化或收益最大化&am…...

深度集成学习不均衡样本图像分类

用五个不同的网络&#xff0c;然后对分类概率进行平均&#xff0c;得到分类结果。基本上分类精度可以提升10% 1.导入基本库 import torch import copy import torch.nn as nn import torchvision.models as models from torchvision import datasets from torchvision import…...

ubuntu 20.04 复现 LVI-SAM

1.环境配置 ubuntu20.04 ROS-Noetic GTSAM 4.0.2 Ceres 1.14.0 前面的我都安装过了&#xff0c;但Ceres 我安装的是 2.2.0,现在安装Ceres 1.14.0 sudo apt-get update sudo apt-get install cmake libgoogle-glog-dev libgflags-dev libatlas-base-dev libeigen3-dev lib…...

每日OJ题_剑指offer数组篇(剑指offer04+剑指offer11+剑指offer21)

目录 剑指 Offer 04二维数组中的查找 代码解析 剑指 Offer 11旋转数组的最小数字 代码解析1 代码解析2 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面 代码解析1 代码解析2 剑指 Offer 04二维数组中的查找 LCR 121. 寻找目标值 - 二维数组 - 力扣&#xff08;LeetCo…...

使用 `tcpdump` 抓取 LiDAR 网络数据包详解

在调试机器人系统或自动驾驶平台时&#xff0c;我们经常需要分析网络中的 LiDAR&#xff08;激光雷达&#xff09;数据流。本文将介绍如何使用 tcpdump 工具对指定 IP 的数据包进行抓取和分析&#xff0c;特别是 LiDAR 数据的典型 UDP 报文。 一、什么是 tcpdump&#xff1f; …...

【NLP 55、强化学习与NLP】

万事开头难&#xff0c;苦尽便是甜 —— 25.4.8 一、什么是强化学习 强化学习和有监督学习是机器学习中的两种不同的学习范式 强化学习&#xff1a;目标是让智能体通过与环境的交互&#xff0c;学习到一个最优策略以最大化长期累积奖励。 不告诉具体路线&#xff0c;首先去做…...

【Linux】单例模式及其在线程池中的应用

&#x1f4e2;博客主页&#xff1a;https://blog.csdn.net/2301_779549673 &#x1f4e2;博客仓库&#xff1a;https://gitee.com/JohnKingW/linux_test/tree/master/lesson &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01; &…...

Ansible的使用2

#### 一、Ansible变量 ##### facts变量 > facts组件是Ansible用于采集被控节点机器的设备信息&#xff0c;比如IP地址、操作系统、以太网设备、mac 地址、时间/日期相关数据&#xff0c;硬件信息等 - setup模块 - 用于获取所有facts信息 shell ## 常用参数 filter…...

十三届蓝桥杯省赛A组 扫描游戏

#算法/线段树 #算法/快读 参考题解: 题解参考 这题思路: 先将坐标进行极角排序,按照顺时针的先后顺序,如果出现两个坐标在一个象限中,我们就先判断这两个坐标是否在同一条直线上,如果在同一条直线上,我们按照离原点最近的长度进行排序 之后,我们通过线段树的方法,定义结点tr[i]…...

Python 序列构成的数组(list.sort方法和内置函数sorted)

list.sort方法和内置函数sorted list.sort 方法会就地排序列表&#xff0c;也就是说不会把原列表复制一份。这 也是这个方法的返回值是 None 的原因&#xff0c;提醒你本方法不会新建一个列 表。在这种情况下返回 None 其实是 Python 的一个惯例&#xff1a;如果一个函数 或者…...

C++类与对象进阶知识深度解析

目录 一、再谈构造函数 &#xff08;一&#xff09;构造函数体赋值 &#xff08;二&#xff09;初始化列表 &#xff08;三&#xff09;成员变量初始化顺序 &#xff08;四&#xff09;explicit关键字 二、static成员 &#xff08;一&#xff09;概念 &#xff08;二&am…...

【机器学习案列】基于LightGBM算法的互联网防火墙异常行为检测:数据不平衡的解决方案

&#x1f9d1; 博主简介&#xff1a;曾任某智慧城市类企业算法总监&#xff0c;目前在美国市场的物流公司从事高级算法工程师一职&#xff0c;深耕人工智能领域&#xff0c;精通python数据挖掘、可视化、机器学习等&#xff0c;发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…...

详解minio部署

MinIO 是一款高性能、开源的分布式对象存储解决方案&#xff0c;专为存储非结构化数据&#xff08;如图片、视频、备份数据等&#xff09;而设计。MinIO 在吞吐量和延迟上表现出高性能提供与 Amazon S3 完全兼容的 API&#xff0c;支持水平扩展&#xff0c;支持端到端加密、访问…...

校园AI体育:科技赋能教育,运动点亮未来

校园AI体育&#xff1a;科技赋能教育&#xff0c;运动点亮未来 在数字化浪潮的推动下&#xff0c;人工智能&#xff08;AI&#xff09;已经悄然走进校园&#xff0c;成为教育领域的一股创新力量。而在体育教育中&#xff0c;AI技术的引入更是为传统体育教学注入了新的活力。校…...

LeetCode算法题(Go语言实现)_35

题目 给你一棵根为 root 的二叉树&#xff0c;请你返回二叉树中好节点的数目。 「好节点」X 定义为&#xff1a;从根到该节点 X 所经过的节点中&#xff0c;没有任何节点的值大于 X 的值。 一、代码实现 func goodNodes(root *TreeNode) int {if root nil {return 0}return d…...

ROS2_control 对机器人控制(不完整,有时间再更新)

ROS2_control 对机器人控制 安装与介绍安装介绍 使用gz 中写法.yaml文件中写法type: joint_state_broadcaster/JointStateBroadcaster的来源 命令接口关节控制command_interfacetransmission CMakelist.txt与package.xml文件 gz_ros2_control与自定义插件例子描述自定义插件使用…...

SAP-ABAP:SAP Enterprise Services Repository(ESR)技术全景解析

以下是对SAP PO中Enterprise Services Repository(ESR)的深度技术解析,包含详细架构设计、开发实践及企业级应用方案: SAP Enterprise Services Repository(ESR)技术全景解析 一、ESR核心架构与组件关系 1. 技术堆栈定位 ┌─────────────────────…...

每日一道leetcode

2130. 链表最大孪生和 - 力扣&#xff08;LeetCode&#xff09; 题目 在一个大小为 n 且 n 为 偶数 的链表中&#xff0c;对于 0 < i < (n / 2) - 1 的 i &#xff0c;第 i 个节点&#xff08;下标从 0 开始&#xff09;的孪生节点为第 (n-1-i) 个节点 。 比方说&…...

通过Aop实现限制修改删除指定账号的数据

1、需求 对于Teach账号创建的数据&#xff0c;其他用户仅仅只有查询的权限&#xff0c;而不能修改和删除。并且部分接口只允许Teach账号访问 2、实现思路 在删除和修改时往往需要传递数据的id&#xff0c;进而可以通过id查询该数据是否由Teach账号创建。当然我们可以在每个删…...

递归实现指数型枚举

我们以n2 为例 我们每次都有选和不选两种 方案&#xff0c;对于每个数字 核心代码 tatic void dfs(int u) { // u代表当前处理的数字if (u > n) { // 终止条件&#xff1a;处理完所有数字for (int i 1; i < n; i) { // 遍历所有数字if (nums[i]) {…...

无代码国产流程引擎 FlowLong 1.1.6 发布

无代码国产流程引擎 FlowLong 1.1.6 于 2025 年 4 月 7 日发布。 FlowLong 是一款纯血国产自研的工作流引擎&#xff0c;具有以下特点&#xff1a; 核心精简&#xff1a;引擎核心仅 8 张表实现逻辑数据存储&#xff0c;采用 json 数据格式存储模型&#xff0c;结构简洁直观。组…...

软考高项-考前冲刺资料-M 类【项目管理类】【光头张老师出品】

重点考点汇总 一、案例答题时需要注意: 1.条目写要清晰,要标注 1、2、3、4、… 2.关键字突出,关键字一定是专业词汇如 “监控”“控制成本”…等等,代替自己平时工作中的用此。 3.尽量多写几点,错了不扣分,但是避免重复写,避免写了一大段的内容,但是表达的是一个观点。…...

LLM Agents项目推荐:MetaGPT、AutoGen、AgentVerse详解

这一部分我们将深入介绍三大备受关注的LLM Agents项目&#xff1a;MetaGPT、AutoGen和AgentVerse&#xff0c;包括它们的背景、设计思路、主要功能、技术亮点以及典型应用场景。 1. MetaGPT&#xff1a;让AI像软件工程团队一样协作 项目背景 MetaGPT由Huang et al.于2023年提…...

win10家庭版安装Docker

win10家庭版本中成功安装Docker&#xff0c;亲测&#xff01; 1、下载Docker 下载地址&#xff1a;http://mirrors.aliyun.com/docker-toolbox/windows/docker-toolbox/ Docker的有CE和EE版&#xff0c;CE为免费版&#xff0c;EE由公司支持的付费版&#xff0c;在此选择CE版本…...

mapbox基础,加载ESRI OpenStreetMap开放街景标准风格矢量图

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.1 ☘️mapboxgl.Map style属性二、🍀加载ESRI OpenStreetMap开放街景标准风…...

【网络安全 | 漏洞挖掘】通过分析JS文件实现接口未授权访问与账户接管

未经许可,不得转载。 文中所述漏洞均已修复,未经授权不得进行非法渗透测试。 文章目录 正文正文 大约一年前,我给我妈买了一辆 2023 款斯巴鲁 Impreza,前提是她得答应我,之后我可以借来做一次“白帽渗透测试”。过去几年我一直在研究其他车企的安全问题,但一直没有机会仔…...

引领东方语言识别新风潮!Dolphin语音模型开创自动语音识别(ASR)新时代

引领东方语言识别新风潮&#xff01;Dolphin语音模型开创自动语音识别&#xff08;ASR&#xff09;新时代 在全球语音识别技术领域&#xff0c;随着人工智能的飞速发展&#xff0c;许多技术巨头纷纷推出了多语言支持的语音识别系统&#xff0c;如Whisper等。然而&#xff0c;尽…...

运动规划实战案例 | 基于四叉树分解的路径规划(附ROS C++/Python仿真)

目录 1 为什么需要四叉树&#xff1f;2 基于四叉树的路径规划2.1 分层抽象2.2 路图搜索2.3 动态剪枝 3 算法仿真3.1 ROS C算法仿真3.2 Python算法仿真 1 为什么需要四叉树&#xff1f; 路径规划的本质是在给定环境中寻找从起点到终点的最优或可行路径&#xff0c;其核心挑战在…...

java设计模式-享元模式

享元模式 基本介绍 1、享元模式(flyweight Pattern)&#xff0c;也叫作蝇量模式&#xff1a;运用在共享技术有效的支持大量细粒度的对象。 2、常用语系统底层开发&#xff0c;解决系统的性能问题。像 数据库连接&#xff0c;里面都是创建好的连接对象&#xff0c;在这些连接对…...

Java 大视界 -- Java 大数据在智慧水利水资源调度与水情预测中的应用创新(180)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…...