【小浩算法cpp实现】删除链表的倒数第n个节点

目录

  • 前言
  • 我的思路
    • 思路一
    • 思路二
  • 我的代码

前言

今天继续学习算法,前几天觉得数组的题还是简单了,今天换个链表的,没想到也是考研期间学过的比较经典的链表算法,就当复习cpp啦!

我的思路

首先我觉得大家应该已经懂了链表是怎么实现删除的,假设待删除的Lnode的前指针是pre,只需要pre -> next= pre->next->next即可。

思路一

我们最常见的思路是把倒数变成正数,所以如果我们能知道链表的长度,那倒数第一个不就是正数最后一个吗,倒数第k个就是正数第n-k+1。这个思路需要遍历2次。

思路二

另一种思路也很经典,我们需要两个指针,假设我们要找第2个元素,那么两个指针一前一后遍历,当前一个指针遍历到链表的最后一个元素时,后一个指针自然就指到倒数第二个元素了(注意删除的时候需要pre指针)。总的来说,我们需要两个指针之间的间距是(k-2),或者让一个指针从头结点开始,先走k个距离

我的代码

#include<iostream>using namespace std;typedef struct Lnode {int x;struct Lnode* next;Lnode(int val) :x(val), next(NULL) {}
};int main() {cout << "请输入链表的总数" << endl;int node_num;cin >> node_num;int node;//把链表的总长度存储在头结点的数据域Lnode* head = new Lnode(node_num);Lnode* p=head;Lnode* q;for (int i = 0; i < node_num; i++) {cin >> node;q = new Lnode(node);p->next = q;p = p->next;}p = head -> next;//输出生成的链表while (p ->next!= NULL) {cout << p->x<<" -> ";p = p->next;}cout << p->x;cout << "\n请输入您想删除倒数第几个节点" << endl;int del_place;cin >> del_place;if (del_place > node_num) {cout << "对不起,您输入的值大于链表总长度,删除失败";}else {Lnode* r=head, *s=head;int diff_place = del_place;while (diff_place != 0) {s = s->next;diff_place--;}while (s -> next != NULL) {s = s->next;r = r->next;}Lnode* del_node;del_node = r->next;r->next = r->next->next;delete del_node;del_node = NULL;}p = head->next;//输出生成的链表while (p->next != NULL) {cout << p->x << " -> ";p = p->next;}cout << p->x;}

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

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

相关文章

pdf在线免费转word网站推荐,纯免费、不注册

pdf在线免费转word网站推荐&#xff0c;纯免费、不注册 pdf在线免费转word文档 https://orcc.online/pdf 不限次数、免费不需要注册&#xff0c;上传之后过一段时间&#xff0c;右侧就会出现转换完成的word文档。 其他工具 时间戳转换 https://orcc.online/timestamp Base…

Nature Climate Change 高引文章 | 朴世龙院士团队等揭示全球变绿及其驱动因子

植被是生物圈的关键组成部分&#xff0c;对调节地球气候和提供生态系统服务具有重要作用。陆地植被生长对全球变化非常敏感。工业革命以来&#xff0c;大气二氧化碳浓度升高、气候变暖、氮沉降增加和土地利用变化等因子&#xff0c;通过复杂的生物物理化学过程&#xff0c;对陆…

Dubbo 集群容错常见方案

Failover Cluster&#xff1a; 失败自动切换&#xff0c;自动重试其它服务器&#xff08;默认&#xff09; Failfast Cluster&#xff1a; 快速失败&#xff0c;立即报错&#xff0c;只发起一次调用 Failsafe Cluster&#xff1a; 失败安全&#xff0c;出现异常时&#xff0c…

Android开发——Fragment

Demo fragment_blank.xml <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_height"match_pare…

韩顺平Java | C25 JDBC和连接池(中)

JDBCUtils工具类 JDBC操作中获取连接和释放资源操作可以封装到JDBCUtils工具类中。 工具类代码 完成mysql的连接和关闭资源 package com.hspedu.jdbc.utils; import java.io.FileInputStream; import java.io.IOException; import java.sql.*; import java.util.Properties…

数据结构--双向链表

在讲双向链表之前&#xff0c;我们先了解一下链表的分类&#xff1a; 链表的结构⾮常多样&#xff0c;主要分为带头与不带头、单向与双向、循环与不循环。三个种类可以任意搭配&#xff0c;所以总共可以形成八种链表&#xff0c;但是最常用的是单向不带头不循环链表和双向带头循…

如何从零开始创建React应用:简易指南

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

经典目标检测YOLOV1模型的训练及验证

1、前期准备 准备好目录结构、数据集和关于YOLOv1的基础认知 1.1 创建目录结构 自己创建项目目录结构&#xff0c;结构目录如下&#xff1a; network CNN Backbone 存放位置 weights 权重存放的位置 test_images 测试用的图…

Tomcat命令行窗口、IDEA中Tomcat控制台 中文乱码问题解决方案

Tomcat出现中文乱码问题 打开Tomcat文件夹下的conf/logging.properties文件&#xff0c;将下图位置中的编码由UTF-8全部替换成GBK 然后重启Tomcat服务器&#xff0c;问题解决 Intellij IDEA启动Tomcat服务器控制台出现中文乱码 解决方案非常简单&#xff0c;按照下图设置控制…

【MySQL】表的增删改查

目录 前言&#xff1a; 新增&#xff08;Create&#xff09;&#xff1a; 查询&#xff08;Retrieve&#xff09;&#xff1a; 别名&#xff1a; 去重&#xff1a;DISTINCT 排序&#xff1a;ORDER BY &#xff1a; 条件查询&#xff1a;WHERE &#xff1a; 分页查询&am…

c++实数排序

例&#xff1a;数的三次方跟 描述&#xff1a;给定一个浮点数n&#xff0c;求它的三次方根。 输入描述&#xff1a;一个浮点数 输出描述&#xff1a;问题的解 保留6位小数 #include<bits/stdc.h> using namespace std; double n,eps1e-8; bool check (double x){retu…

【新手入门必看】从零开始学指针

我使用VS CODEMSYS2的编译环境进行学习&#xff0c;想使用VS CODE进行C/C代码编写的小伙伴参考这篇文章进行环境配置VS Code 配置 C/C 编程运行环境&#xff08;保姆级教程&#xff09; 一、指针的引入 指针地址 #include <stdio.h>int main() {int a 10;printf(&quo…

Git的操作和使用

一、基本操作 1、创建git本地仓库 &#xff08;1&#xff09;创建目录&#xff1a;mkdir gitcode &#xff08;2&#xff09;进入目录&#xff1a;cd gitcode/ &#xff08;3&#xff09;查询目录内容&#xff1a;ls &#xff08;4&#xff09;在当前目录下创建git本地仓库…

java算法day3

移除链表元素设计链表翻转链表两两交换链表中的结点 移除链表元素 ps&#xff1a;有时候感觉到底要不要写特判&#xff0c;你想到了就写&#xff01;因为一般特判有一劳永逸的作用。 解法有两种&#xff0c;一种是不用虚拟头结点&#xff0c;另一种就是用虚拟头结点。 这里我…

QT中表格控件使用

一、QTableView表头设置样式 //控件样式 QString setcolor"QHeaderView{""border:0px solid #ffffff;""outline:0px;""background:#000000;""}""QHeaderView::section:horizontal:first{""border:1px solid…

React-基础语法学习

1、教程&#xff1a;井字棋游戏 本教程将引导你逐步实现一个简单的井字棋游戏&#xff0c;并且不需要你对 React 有任何了解。在此过程中你会学习到一些编写 React 程序的基本知识&#xff0c;完全理解它们可以让你对 React 有比较深入的理解。 1.1、教程分成以下几个部分&am…

3D感知生成对抗网络的高斯溅射解码器

Gaussian Splatting Decoder for 3D-aware Generative Adversarial Networks 3D感知生成对抗网络的高斯溅射解码器 Florian Barthel1, 2  Arian Beckmann1  Wieland Morgenstern1  Anna Hilsmann1  Peter Eisert1,2 Florian Barthel 1, 2 阿里安贝克曼Wieland晨星Anna Hils…

关于动画这一篇就够了

Android动画框架是一个强大的工具集合&#xff0c;用于创建和管理各种动画效果。它提供了一系列的类和接口&#xff0c;使得开发者能够轻松地定义和控制动画的行为&#xff0c;包括动画的持续时间、插值器、动画类型等。在Android中&#xff0c;动画主要分为三类&#xff1a;补…

【Godot4自学手册】第三十九节利用shader(着色器)给游戏添加一层雾气效果

今天&#xff0c;主要是利用shader给游戏给地宫场景添加一层雾气效果&#xff0c;增加一下气氛&#xff0c;先看一下效果&#xff1a; 一、新建ParallaxBackground根节点 新建场景&#xff0c;根节点选择ParallaxBackground&#xff0c;命名为Fog&#xff0c;然后将该场景保…

不要小看在线文档编辑工具,它才是提高工作效率的法宝

在数字化的今天&#xff0c;工作方式正变得越来越灵活&#xff0c;远程办公和团队协作已成日常。这个时候&#xff0c;传统的文档处理方式已经无法满足快速发展的业务需求。在线文档编辑工具&#xff0c;正逐渐成为提高团队工作效率的秘密武器。它能够让团队成员无论身处何地&a…