iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++怎么用数组模拟链表
  • 574
分享到

C++怎么用数组模拟链表

2023-06-26 05:06:26 574人浏览 泡泡鱼
摘要

这篇文章的内容主要围绕c++怎么用数组模拟链表进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!前言链表是指由一系列储存在非连续储存空间 结点组成的储存

这篇文章的内容主要围绕c++怎么用数组模拟链表进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!

前言

链表是指由一系列储存在非连续储存空间 结点组成的储存结构。每个结点由两部分组成:一是储存元素的数据域,一是储存下一个节点地址的指针域。用数组模拟链表可以十分清晰明了地理解这一定义。

在这里,我们简单地介绍一下单链表和双链表两种链表以及用数组模拟实现它们的方式。

1.单链表

单链表是指针方向单向的链表,即a结点的指针域储存着b结点的地址,而b结点的指针域内没有储存a结点的地址。在访问时,可以由a到b访问,而不能由b到a访问。

C++怎么用数组模拟链表

如图可以清晰地看到,各个结点的指向都是单向的。

Q: 那么,如何用数组来实现它呢?

A: 方法如下

在k结点右侧插入元素x。先将x赋值给该节点的数据域(e[idx]),然后将k结点的指针域赋值给该结点的指针域,最后将k结点的指针域储存的地址改为该节点的地址。

void add(int k, int x){    e[idx] = x;    ne[idx] = ne[k];    ne[k] = idx++;}
删除k结点指向的结点。这里所指的删除,是将k的指向改为该结点的指向。原本为a -> b -> c,改为a -> c,b结点依然存在,只是没有其他结点指向它,也就无法通过链表访问它,我们认为它就再链表上被删除了。
void remove(int k){    ne[k] = ne[ne[k]];}

读取链表。读取链表只用注意一点,在用单指针扫描时不是将指针位置右移,而是将指针移动到该结点指向的位置。

for (int i = head; i != -1; i = ne[i]) cout << e[i] << ' ';cout << endl;

主要的操作就是如此,下边看看完整代码:

这是较为经典的写法,我个人认为有些麻烦,head不必单独拿出来写一个函数。但是有助于理解。

#include<iOStream>using namespace std;const int M = 1e5 + 10;int m, k, x, idx, head;int e[M], ne[M];void init(){    head = -1, idx = 0;}void add_head(int x){    e[idx] = x;    ne[idx] = head;    head = idx++;}void remove(int k){    ne[k] = ne[ne[k]];}void add(int k, int x){    e[idx] = x;    ne[idx] = ne[k];    ne[k] = idx++;}int main(){    init();    cin >> m;    while (m--)    {        char op;        cin >> op;        if (op == 'H')        {            cin >> x;            add_head(x);        }        else if (op == 'D')        {            cin >> k;            if (!k) head = ne[head];            remove(k - 1);        }        else        {            cin >> k >> x;            add(k - 1, x);        }    }    for (int i = head; i != -1; i = ne[i]) cout << e[i] << ' ';    cout << endl;    return 0;}

这种写法稍微简便一些,用a[0]替代head。

#include<iostream>using namespace std;const int M = 1e5 + 10;int m, k, x, idx, head;int e[M], ne[M];void init(){    ne[0] = -1, idx = 1;}void remove(int k){    ne[k] = ne[ne[k]];}void add(int k, int x){    e[idx] = x;    ne[idx] = ne[k];    ne[k] = idx++;}int main(){    init();    cin >> m;    while (m--)    {        char op;        cin >> op;        if (op == 'H')        {            cin >> x;            add(0, x);        }        else if (op == 'D')        {            cin >> k;            if (!k) head = ne[head];            remove(k);        }        else        {            cin >> k >> x;            add(k, x);        }    }    for (int i = ne[0]; i != -1; i = ne[i]) cout << e[i] << ' ';    cout << endl;    return 0;}

2.双链表

双链表顾名思义就是指针方向双向的链表。

C++怎么用数组模拟链表

可以看到除了头尾他们的指针都是双向的。

它的实现方法如下:

创建开始和结束结点。0表示开始,1表示结束,互相指向,在插入时直接往中间插入即可。

void init(){r[0] = 1, l[1] = 0;idx = 2;}

插入结点。双链表插入结点的方法与单链表相同,但是操作要稍微复杂一些,这是在k结点右边插入一结点的代码。它要顾及结点左右的结点指向,对于两边都要操作。面临在k结点左边插入一结点时,不必单独在写一个函数,而改成在l[k]结点的右边插入一个结点。

void add(int k, int x){a[idx] = x;r[idx] = r[k], l[idx] = l[r[k]];l[r[k]] = idx, r[k] = idx;idx++;}

删除节点。删除结点与插入结点同理,我就不多赘述了。

void remove(int k){r[l[k]] = r[k];l[r[k]] = l[k];}

输出链表。可以选择输出方向,这里是从左往右输出。

for (int i = r[0]; i != 1; i = r[i])cout << a[i] << ' ';cout << endl;

以下是完整代码:

#include<iostream>using namespace std;const int N = 1e5 + 10;int a[N], l[N], r[N];int idx;int m;void init(){r[0] = 1, l[1] = 0;idx = 2;}void add(int k, int x){a[idx] = x;r[idx] = r[k], l[idx] = l[r[k]];l[r[k]] = idx, r[k] = idx;idx++;}void remove(int k){r[l[k]] = r[k];l[r[k]] = l[k];}int main(){init();cin >> m;while (m--){int k, x;string op;cin >> op;if (op == "L"){cin >> x;add(0, x);}else if (op == "R"){cin >> x;add(l[1], x);}else if (op == "D"){cin >> k;remove(k + 1);}else if (op == "IL"){cin >> k >> x;add(l[k + 1], x);}else if (op == "IR"){cin >> k >> x;add(k + 1, x);}}for (int i = r[0]; i != 1; i = r[i])cout << a[i] << ' ';cout << endl;return 0;}

感谢你的阅读,相信你对“C++怎么用数组模拟链表”这一问题有一定的了解,快去动手实践吧,如果想了解更多相关知识点,可以关注编程网网站!小编会继续为大家带来更好的文章!

--结束END--

本文标题: C++怎么用数组模拟链表

本文链接: https://www.lsjlt.com/news/306926.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++怎么用数组模拟链表
    这篇文章的内容主要围绕C++怎么用数组模拟链表进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!前言链表是指由一系列储存在非连续储存空间 结点组成的储存...
    99+
    2023-06-26
  • C++如何用数组模拟链表
    目录前言1.单链表2.双链表总结前言 链表是指由一系列储存在非连续储存空间 结点组成的储存结构。每个结点由两部分组成:一是储存元素的数据域,一是储存下一个节点地址的指针域。用数组模拟...
    99+
    2024-04-02
  • C++数组模拟之单链表与双链表和栈和队列的实现过程
    目录前引一、数组模拟实现单链表1.1 数组模拟的单链表解析1.2 数组模拟实现单链表例题二、数组模拟实现双链表2.1 数组模拟实现双链表解析2.2 数组模拟实现双链表例题三、数组模拟...
    99+
    2023-02-13
    C++数组模拟单链表 C++数组模拟双链表 C++数组模拟队列
  • C#中的数组怎么转化成链表
    在C#中,可以使用`LinkedList`类来将数组转换为链表。`LinkedList`类是C#中的一个内置泛型类,用于表示双向链表...
    99+
    2023-09-09
    C#
  • C++中的数组、链表与哈希表
    目录数组和链表数组链表什么是链表?链表的操作双向链表(list)list的成员函数哈希表什么是哈希表?哈希碰撞哈希表应用场景构建哈希表哈希表基本使用Leetcode对应题目前缀和差分...
    99+
    2024-04-02
  • web数组与链表到单链表的反转怎么理解
    本篇内容主要讲解“web数组与链表到单链表的反转怎么理解”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web数组与链表到单链表的反转怎么理解”吧!数组与链表数组最大的一个特点就是,需要一块连续的...
    99+
    2023-06-16
  • PHP中怎么利用数组实现单链表
    本篇文章为大家展示了PHP中怎么利用数组实现单链表,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。PHP数组实现单链表结构此类主要是依靠PHP强大的数组系统来模拟出单链表类型的数据结构。 本人完全凭借...
    99+
    2023-06-17
  • C#集合的链表怎么用
    这篇文章主要介绍了C#集合的链表怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C#集合的链表怎么用文章都会有所收获,下面我们一起来看看吧。LinkedList<T>是一个双向链表,其元素会指向...
    99+
    2023-06-30
  • C++怎么划分链表
    这篇文章主要讲解了“C++怎么划分链表”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++怎么划分链表”吧!Partition List 划分链表Given a linked list an...
    99+
    2023-06-20
  • C++怎么旋转链表
    这篇文章主要介绍“C++怎么旋转链表”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++怎么旋转链表”文章能帮助大家解决问题。Rotate List 旋转链表Given the head&...
    99+
    2023-06-19
  • c++中数组怎么表示
    c++ 中数组是一种用于存储具有相同数据类型的一组连续内存单元的数据结构。数组的元素使用下标运算符访问,其下标从 0 开始。数组的属性包括尺寸(存储的元素数量)、数据类型(元素的数据类型...
    99+
    2024-04-26
    c++
  • 教你怎么用Java数组和链表实现栈
    目录一、何为栈?二、用数组实现栈三、链表实现栈四、测试一、何为栈? 栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对...
    99+
    2024-04-02
  • C语言中单链表怎么用
    这篇文章将为大家详细讲解有关C语言中单链表怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、单链表概念:链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序...
    99+
    2023-06-29
  • C++怎么实现每k个一组翻转链表
    本篇内容主要讲解“C++怎么实现每k个一组翻转链表”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++怎么实现每k个一组翻转链表”吧!Reverse Nodes in k-Group 每k个一组...
    99+
    2023-06-20
  • C++怎么实现单链表
    本文小编为大家详细介绍“C++怎么实现单链表”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++怎么实现单链表”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。单链表链表内存空间不一定连续,其扩展性较好。多余的不多...
    99+
    2023-07-02
  • C语言中链表与单链表有什么用
    这篇文章将为大家详细讲解有关C语言中链表与单链表有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。链表是什么及链表的优势链表是一种介于数组的另外一种数据结构:我们知道数组可以存放很多的元素,这些元素都...
    99+
    2023-06-29
  • C++链表类怎么封装
    这篇文章主要介绍“C++链表类怎么封装”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++链表类怎么封装”文章能帮助大家解决问题。1.CList.h#ifndef CLIST_H#defi...
    99+
    2023-06-30
  • C语言 数据结构之数组模拟实现顺序表流程详解
    目录线性表和顺序表线性表顺序表静态顺序表动态顺序表代码已经放在Gitee上,需要可以小伙伴可以去看看 用C语言数组模拟实现顺序表 Gitee 线性表和顺序表 线性表 线性表(line...
    99+
    2024-04-02
  • php数组怎么进行堆栈的模拟
    这篇文章给大家分享的是有关php数组怎么进行堆栈的模拟的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。PHP开发环境搭建工具有哪些一、phpStudy,是一个新手入门最常用的开发环境。二、WampServer,Wa...
    99+
    2023-06-14
  • JavaScript怎么在数组上模拟max方法
    这篇“JavaScript怎么在数组上模拟max方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作