用C++类实现单向链表的增删查和反转操作方法
数据结构这东西,理解起来不算难,但是实现难度就不小了,虽然思路很清晰,但不知道从何下手还有语言的细节问题一直是阻碍初学者的主要障碍(比如我)。今天用了一下午时间终于独立完成了链表操作。
找网上的代码,大多用了结构体,还有些并不适合刚学c++或者数据结构的人看,于是我是用类写的,代码比较符合学生的习惯和水平。
先看类定义
class node { public: int data; node *next; }; class linklist { node *h; ……//一些函数 }
两个类,node用来表示结点,node *next,表示next是指向node型的指针(一些同学看不懂这句,会和构造函数弄混),linklist类是存放头指针和定义操作函数用的。
一、整表的创建
整表创建有两种方法,头插(倒叙)和尾插(顺序),这里只说头插。
void head(linklist &l,int n) { node *p; p=new node; l.h=p;//定义头结点和投指针 p->data=n;//头指针的数据域是结点个数 p->next=NULL;//最末结点的后继必须为空 for(int i=0;i<n;i++)//创建n个新结点 { node *q=new node; cin>>q->data; q->next=p->next; p->next=q;//每个新结点都放在头结点后面 } }
二、单结点插入
void insert(linklist &l,int n,int num) { node *p=l.h; for(int i=0;i<n;i++) { p=p->next; }//找到插入的位置 node *q=new node; q->next=p->next; p->next=q; q->data=num; }
三、单结点删除
void del(linklist &l,int n) { node *p=l.h; for(int i=0;i<n-1;i++) { p=p->next; }//找到删除的位置 node *q=p; q=q->next; p->next=q->next; delete q;//释放空间 }
四、查找结点
void search(linklist &l,int n) { node *p=l.h; for(int i=0;i<n;i++) { p=p->next; } cout<<p->data<<endl; }
五、倒置
由于头插是倒叙输出,就想倒置,网上好多代码都是新建一个链表,或者用到尾指针双向链表之类,我觉得不会这么麻烦于是就想了这么个算法
void reverse(linklist l) { node *p=l.h; node *q; p=p->next; while(p->next) { q=p->next; p->next=q->next; // q->next=p; //如果把下面两句换成这句,就会悲剧。 q->next=l.h->next; l.h->next=q; } }
一下午时间主要就耽误在这里了,我一开始写的就是注释那句话,后来总是输出头结点的数据,仔细观察发现原来是头指针跟着头结点换到了最后面,然后这个问题通过下面两句解决,保证头指针永远在表头。
六、结语
写到这里,终于明白为什么网上包括书上很多代码都是看懂容易写起来难,因为书或者博客作者就不会把他犯过的错误贴出来,一些简单的代码也没有很多注释,自己写的时候也理解他们了,想详细写出每一步的理由还是太难了,无法表达的东西太多,所以想掌握一个东西还是亲手实践,多犯错误才能进步,因为书上或网上很难找到细节之处易犯的错误,以为自己会了的时候就用纸写出来,到头来会发现还是不会……循环几次,就差不多了。
以上这篇用C++类实现单向链表的增删查和反转操作方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。
您可能感兴趣的文章
- 04-02c语言函数调用后清空内存 c语言调用函数删除字符
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言用函数写分段 用c语言表示分段函数
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段函数
- 04-02c语言调用函数求fibo C语言调用函数求阶乘
- 01-10数据结构课程设计-用栈实现表达式求值的方法详解
- 01-10使用OpenGL实现3D立体显示的程序代码
- 01-10HDOJ 1443 约瑟夫环的最新应用分析详解
- 01-10深入理解C++中常见的关键字含义
阅读排行
本栏相关
- 04-02c语言函数调用后清空内存 c语言调用
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言的正则匹配函数 c语言正则表达
- 04-02c语言用函数写分段 用c语言表示分段
- 04-02c语言中对数函数的表达式 c语言中对
- 04-02c语言编写函数冒泡排序 c语言冒泡排
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段
- 04-02C语言中怎么打出三角函数 c语言中怎
- 04-02c语言调用函数求fibo C语言调用函数求
随机阅读
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 04-02jquery与jsp,用jquery
- 01-11ajax实现页面的局部加载
- 01-10SublimeText编译C开发环境设置
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法实例总结
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文