双向链表逆置c语言,【C++】实现双向链表的所有操作,包括逆置双链表(三种方法)...

建立源文件List.cppinclude "List.h"

int main()

{

Test();

system("pause");

return 0;

}

建立头文件List.h#ifndef __LISH_H__

#define __LISH_H__

#include

using namespace std;

typedef int DataType;

struct ListNode

{

ListNode(DataType x)

:_next(NULL)

, _prev(NULL)

, _data(x)

{}

ListNode* _next;

ListNode* _prev;

DataType _data;

};

class List

{

public:

List()

:_head(NULL)

,_tail(NULL)

{}

List(const List& s)

:_head(NULL)

, _tail(NULL)

{

ListNode* cur = s._head;

while (cur)

{

this->PushBack(cur->_data);

cur = cur->_next;

}

}

List& operator= (const List& s)

{

//先删除节点,再插入节点

if (&s != this)

{

ListNode* pcur = _head;

while (pcur)

{

ListNode* del = pcur;

pcur = pcur->_next;

delete del;

del = NULL;

}

ListNode* cur = s._head;

while (cur)

{

this->PushBack(cur->_data);

cur = cur->_next;

}

}

return *this;

}

~List()

{

ListNode* cur = _head;

while (cur)

{

ListNode* del = cur;

cur = cur->_next;

delete del;

del = NULL;

}

}

//尾插

void PushBack(DataType x)

{

//分:0节点   1、多节点两种情况

if (_head == NULL)

{

_head = new ListNode(x);

_tail = _head;

_tail->_next = NULL;

}

else

{

ListNode* cur = new ListNode(x);

_tail->_next = cur;

cur->_prev = _tail;

_tail = cur;

_tail->_next = NULL;

}

}

//尾删

void PopBack()

{

if (_head == _tail)

{

if (_head != NULL)

{

delete _head;

_head = NULL;

_tail = NULL;

}

else

{

return;

}

}

else

{

ListNode* prev = _tail->_prev;

delete _tail;

_tail = NULL;

_tail = prev;

_tail->_next = NULL;

}

}

//头插

void PushFront(DataType x)

{

if (_head == NULL)

{

PushBack(x);

}

else

{

ListNode* index = new ListNode(x);

index->_next = _head;

_head->_prev = index;

_head = index;

_head->_prev = NULL;

}

}

//头删

void PopFront()

{

if (_head == _tail)

{

PopBack();

}

else

{

ListNode* del = _head;

ListNode* next = _head->_next;

_head = next;

_head->_prev = NULL;

delete del;

del = NULL;

}

}

//插入元素

void Insert(size_t pos, DataType x)

{

//分:是尾插   不是尾插    两种情况

ListNode* cur = _head;

while (--pos)

{

cur = cur->_next;

}

if (cur == _tail)

{

PushBack(x);

}

else

{

ListNode* index = new ListNode(x);

ListNode* prev = cur->_prev;

index->_next = cur;

cur->_prev = index;

prev->_next = index;

index->_prev = prev;

}

}

//查找元素

ListNode* Find(DataType x)

{

ListNode* cur = _head;

while (cur)

{

if (cur->_data == x)

{

return cur;

}

cur = cur->_next;

}

return NULL;

}

//删除元素

void Erase(ListNode* pos)

{

if (pos == _head)

{

PopFront();

}

else if (pos == _tail)

{

PopBack();

}

else

{

ListNode* prev = pos->_prev;

ListNode* next = pos->_next;

prev->_next = next;

next->_prev = prev;

delete pos;

pos = NULL;

}

}

//逆置方法一:从两头走,交换数据

/*void Reverse()

{

ListNode* begin = _head;

ListNode* end = _tail;

while (!((begin == end) || (end->_next == begin)))

{

swap(begin->_data, end->_data);

begin = begin->_next;

end = end->_prev;

}

}*/

//逆置方法二:交换节点的前驱和后继

/*void Reverse()

{

ListNode* cur = _head;

while (cur)

{

swap(cur->_prev, cur->_next);

cur = cur->_prev;

}

swap(_head, _tail);

}*/

//逆置方法三:摘节点,头插该节点

void Reverse()

{

ListNode* cur = _head;

ListNode* newhead = NULL;

while (cur)

{

ListNode* tmp = cur;

cur = cur->_next;

if (newhead == NULL)

{

newhead = tmp;

newhead->_next = NULL;

newhead->_prev = NULL;

_head = _tail = newhead;

}

else

{

newhead->_prev = tmp;

tmp->_next = newhead;

newhead = tmp;

_head = newhead;

_head->_prev = NULL;

}

}

}

//打印

void PrintList()

{

ListNode* cur = _head;

while (cur)

{

cout <_data <";

cur = cur->_next;

}

cout <

}

private:

ListNode* _head;

ListNode* _tail;

};

void Test()

{

List s;

s.PushBack(1);

s.PushBack(2);

s.PushBack(3);

s.PushBack(4);

s.PushBack(5);

s.PrintList();

s.PopBack();

s.PrintList();

s.PushFront(0);

s.PrintList();

s.PopFront();

s.PrintList();

s.Insert(2, 10);

s.PrintList();

s.Reverse();

s.PrintList();

}

#endif //__LIST_H__

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

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

相关文章

MIT 的新型开源系统 Taco 将数据分析速度提升 100 倍 !(附论文)

来源&#xff1a;全球人工智能 概要&#xff1a;麻省理工学院&#xff08;MIT&#xff09;开发的一种新型计算机系统为涉及“稀疏张量”&#xff08;sparse tensor&#xff09;的计算加快了速度&#xff0c;稀疏张量是主要由0组成的多维数据数组。 麻省理工学院&#xff08…

android动态设置文本居中显示图片,Android DrawableTextView图片文字居中显示实例

在我们开发中&#xff0c;TextView设置Android:drawableLeft一定使用的非常多&#xff0c;但Drawable和Text同时居中显示可能不好控制&#xff0c;有没有好的办法解决呢&#xff1f;小编的方案是通过自定义TextView实现。实现的效果图&#xff1a;注&#xff1a;第一行为原生Te…

洪小文:以科学的方式赤裸裸地剖析AI(二)|从寒冬到复兴

来源&#xff1a;微软研究院AI头条 概要&#xff1a;1956年&#xff0c;在达特茅斯会议之后&#xff0c;包括很多国家政府&#xff0c;美国国家科学基金会、军方&#xff0c;大家满怀希望投了很多钱。但是到1975年以后发生了几件事情&#xff0c;让AI进入了寒冬。 谈AI的历史&a…

ios android分享代码,快速插入代码块——iOS Android

昨天看到一篇分享插入代码块的文章 Xcode 快速开发 代码块&#xff0c;想到把我知道的其它方案也分享一下iOS篇这种方案可行&#xff0c;但效率不够高方案二&#xff1a;DashDash 目前只有 macOS 版本&#xff0c;免费&#xff0c;但有限制(会有时间延时&#xff0c;可以付费取…

重磅!腾讯发布AI生态计划将赋能1000合作伙伴!

来源&#xff1a; 腾讯科技 概要&#xff1a;11月8日&#xff0c;腾讯2017全球合作伙伴大会&#xff0c;在“创想人工智能”论坛上&#xff0c;腾讯披露了人工智能的整体布局&#xff0c;以及在众多研究领域的最新技术进展与应用探索。 11月8日&#xff0c;腾讯2017全球合作伙伴…

android 遍历所有view,Android 算法:遍历ViewGroup找出所有子View

1.用递归的方式实现// 遍历viewGrouppublic int traverseViewGroup(View view) {int viewCount 0;if (null view) {return 0;}if (view instanceof ViewGroup) {//遍历ViewGroup,是子view加1&#xff0c;是ViewGroup递归调用for (int i 0; i < ((ViewGroup) view).getChi…

重磅:ATT的《5G移动边缘计算白皮书》!

来源&#xff1a;5G 概要&#xff1a;今天&#xff08;11月8日&#xff09;&#xff0c;AT&T宣布&#xff0c;其正在硅谷建设MEC&#xff08;移动边缘计算&#xff09;测试外场。 精彩报告

android 6.0 adb,安卓6.0,adb停用系统更新

集各路大神的方法&#xff0c;汇总一下。1、下载adb工具包2、进入开发者选项&#xff0c;打开“手机打开USB调试”&#xff0c;手机上确认允许电脑usb调试。3、手机上断开wifi和移动网络&#xff0c;应用管理里找到系统更新-存储-删除数据&#xff0c;再退出进入系统更新。4、电…

GoogleNet是怎么理解图像的?谷歌大神教你读懂「神经特征可视化」

来源&#xff1a;雷克世界 编译&#xff1a;嗯~阿童木呀 概要&#xff1a;特征可视化使我们能够看到在ImageNet数据集上训练的GoogLeNet是如何构建对多层图像的理解的。 边缘&#xff08;层 conv2d0&#xff09; 纹理&#xff08;层 mixed3a&#xff09; 模式&#xff08;层 mi…

android studio云测,Android studio 下的robotium自动化测试和持续集成

【背景介绍】Android Studio 是一个Android开发环境&#xff0c;基于IntelliJ IDEA. 类似 Eclipse ADT&#xff0c;Android Studio 提供了集成的 Android 开发工具用于开发和调试。作为官方主推的开发环境和停止对其他开发IDE的支持&#xff0c;Android Studio将成为今后唯一的…

博通收购高通12张PPT深度解析!

来源&#xff1a;国际电子商情 概要&#xff1a;11月6日&#xff0c;博通官方发出公告&#xff0c;宣布将以每股60美元现金&#xff0c;另加10美元公司股票收购高通全部流通股&#xff0c;交易总价值达到1300亿美元。 高通昨日证实已收到了博通公司发出的主动收购提议&#xf…

华为鸿蒙显示安卓,被谷歌除名,华为6月2日发布鸿蒙反击,开机界面已流出!...

前几天谷歌发布了Android 12的公测版更新名单&#xff0c;小米、OV、一加、索尼、三星等赫然在列&#xff0c;唯独没有华为&#xff01;这是一件很明显的事情&#xff0c;谷歌已经把华为从安卓系统中“除名”&#xff0c;华为现在要做产品也不得不自力更生了。作为对谷歌除名的…

腾讯AI战略详解:技术社会与创新图景 | 2017互联网科技创新白皮书重磅首发

来源&#xff1a;腾讯研究院 概要&#xff1a;11月8日上午&#xff0c;以“开放创想”为主题的2017腾讯全球合作伙伴大会在成都开幕。 11月8日上午&#xff0c;以“开放创想”为主题的2017腾讯全球合作伙伴大会在成都开幕&#xff0c;来自全球的350位国内外顶级大咖、500家主流…

腾讯「AI In All」的背后,是开放AI技术能力,探索腾讯应用场景

来源&#xff1a;灯塔大数据 概要&#xff1a;过去一年中&#xff0c;我们听到不少公司在谈到未来的时候都会谈到一个词&#xff0c;叫做「All In AI」&#xff0c;腾讯在 AI 方面的战略也用一个词概括&#xff0c;那就是「AI In All」。 「过去一年中&#xff0c;我们听到不少…

AI时代,企业如何利用机器学习技术驱动业务发展?

来源&#xff1a;全球人工智能 概要&#xff1a;在过去的这些年&#xff0c;为了构建基础设施&#xff0c;数据社区专注于聚集和收集数据&#xff0c;并使用数据来改进决策。 为了成为一个机器学习公司&#xff0c;你需要工具和流程去克服数据、工程和模型方面的挑战。 在过去…

自动移动文字html,css怎么移动文字?

css怎么移动文字&#xff1f;下面本篇文章给大家介绍一下方法。有一定的参考价值&#xff0c;有需要的朋友可以参考一下&#xff0c;希望对大家有所帮助。css怎么移动文字&#xff1f;首先可以用个容器来包住文字&#xff0c;给宽和高。然后&#xff0c;可以使用多种方法来移动…

医学知识图谱构建技术与研究进展

来源&#xff1a; 人机与认知实验室 概要&#xff1a;医学知识图谱是实现智慧医疗的基石&#xff0c;有望带来更高效精准的医疗服务。 摘要&#xff1a;医学知识图谱是实现智慧医疗的基石&#xff0c;有望带来更高效精准的医疗服务。然而&#xff0c;现有知识图 谱构建技术在医…

android animatorset 监听,Android源码分析--动画框架AnimatorSet

这一节&#xff0c;我要介绍的是AnimatorSet。一提到android的动画&#xff0c;一定会涉及到AnimatorSet&#xff0c;因为他太好用了。它所封装的接口让很多复杂的动画叠加变得容易。AnimatorSet是继承于Animator这个是非常重要的&#xff0c;因为AnimatorSet可以不停的叠加自身…

2017年全球最具影响力50家机器人公司排行榜!我国企业基本都有研发类似产品!

来源&#xff1a;机器视觉 概要&#xff1a;ABB Robotics是一家成立于1988年的瑞士工业机器人公司&#xff0c;主要涉及&#xff08;新&#xff09;能源和矿业、基础设施、生产/农业、供应链四个领域&#xff0c;关键技术包括数字化连接、工业设备和系统安装。 以下就是 2017 年…

android go 最小内存,谷歌更新Android Go新规则,由原本的支持低于1G内存设备上升到2G...

原标题&#xff1a;谷歌更新Android Go新规则&#xff0c;由原本的支持低于1G内存设备上升到2G说起安卓系统想必很多人都知道&#xff0c;但是你知不知道还有一个叫做安卓Go的系统呢&#xff1f;这个安卓Go的系统最初是谷歌在I/O 2017全球开发者大会上所发布的&#xff0c;它的…