博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
双链表的相关操作
阅读量:4134 次
发布时间:2019-05-25

本文共 3239 字,大约阅读时间需要 10 分钟。

// DoubleLinkTable.cpp : Defines the entry point for the console application.#include "stdafx.h"#include
#include
using namespace std;typedef struct node{ char data; struct node *next,*pre;}ListNode;typedef ListNode * LinkList; LinkList CreateListF(void)//头插入法{ LinkList head=NULL,ptemp=NULL; head = (ListNode *)malloc(sizeof(ListNode));//头结点初始化 head->data = ' '; head->next = NULL; head->pre = NULL; ptemp=head;//用ptemp代替头结点指针 ListNode *newNode; cout<<"请输入字符串并回车,则尾插入法形成的单链表如下:"<
data=ch; if(ptemp->next==NULL) { newNode->next=ptemp; newNode->pre=NULL; ptemp->pre=newNode; ptemp->next=NULL; } else { newNode->next=ptemp; newNode->pre=NULL; ptemp->pre=newNode; } ptemp=newNode;//ptemp要不断向前移动 ch=getchar(); } head=new ListNode();//重新建立一个空数据的头结点 head->data=' '; head->next=ptemp; head->pre=NULL; ptemp->pre=head; return head;}LinkList CreateListR(void)//尾插入法{ LinkList head=NULL,ptemp=NULL; head = (ListNode *)malloc(sizeof(ListNode)); head->data = ' '; head->next = NULL; head->pre = NULL; ptemp=head; ListNode *newNode; cout<<"请输入字符串并回车,则尾插入法形成的单链表如下:"<
data=ch; ptemp->next = newNode; newNode->pre = ptemp; newNode->next = NULL; ptemp = ptemp->next; ch=getchar(); } return head;}void DeleteNode(LinkList &head,char value){ assert(head != NULL); ListNode *current = NULL; ListNode *temp = NULL; current = head; while( NULL != current->next) { if ( value == current->next->data) { temp = current->next; if(temp->next==NULL)//删除的结点是尾结点 current->next=NULL; else //删除的结点是头或中间结点 { current->next = temp->next; temp->next->pre=current; } free(temp); } else current = current->next; }}void InsertNode(LinkList &head,char value){ assert(head!=NULL); int pos,tag,index=0; ListNode *current=head; ListNode *newNode=new ListNode(); newNode->data=value; cout<<"请输入插入方式:0——头部;1——尾部;2——中间。"<
>pos; if(pos==2) { cout<<"请输入插入的位置:"; cin>>tag; } switch(pos) { case 0: newNode->next=head->next; head->next->pre=newNode; head->next=newNode; newNode->pre=head; break; case 1: while(current->next) current=current->next; current->next=newNode; newNode->pre=current; newNode->next=NULL; break; case 2: while(index
next!=NULL) { index++; current=current->next; } if(index!=tag) exit(-1); newNode->next=current; newNode->pre=current->pre; current->pre->next=newNode; current->pre=newNode; /*newNode->pre=current->pre; current->pre->next=newNode; newNode->next=current; current->pre=newNode;*/ break; default: break; }}void print(LinkList head){ while(head->next!=NULL) { cout<
next->data; head=head->next; if(head->next!=NULL) cout<<"<——> "; } cout<
next!=NULL) { len++; head=head->next; } return len;}void Reverse(LinkList head){ if(head->next==NULL) exit(-1); ListNode*p1; p1=head->next; head->next=NULL; p1->pre=NULL; ListNode *p2,*p3; p2=p1->next; while(p2) { if(p2->next!=NULL) { p3=p2->next; p2->pre->next=p3; p3->pre=p2->pre; p2->next=p1; p1->pre=p2; } else //尾部结点 { p2->pre->next=NULL; p2->pre=head; head->next=p2; p2->next=p1; p1->pre=p2; p3=NULL; } p1=p2; p2=p3; }}int _tmain(int argc, _TCHAR* argv[]){ /*LinkList head=CreateListF();*/ LinkList head=CreateListR(); print(head); cout<<"After DeleteNode():"<

转载地址:http://wdsvi.baihongyu.com/

你可能感兴趣的文章
最长递增子序列
查看>>
从一列数中筛除尽可能少的数,使得从左往右看这些数是从小到大再从大到小...
查看>>
判断一个整数是否是回文数
查看>>
经典shell面试题整理
查看>>
腾讯的一道面试题—不用除法求数字乘积
查看>>
素数算法
查看>>
java多线程环境单例模式实现详解
查看>>
将一个数插入到有序的数列中,插入后的数列仍然有序
查看>>
在有序的数列中查找某数,若该数在此数列中,则输出它所在的位置,否则输出no found
查看>>
万年历
查看>>
作为码农你希望面试官当场指出你错误么?有面试官这样遭到投诉!
查看>>
好多程序员都认为写ppt是很虚的技能,可事实真的是这样么?
查看>>
如果按照代码行数发薪水会怎样?码农:我能刷到公司破产!
查看>>
程序员失误造成服务停用3小时,只得到半月辞退补偿,发帖喊冤
查看>>
码农:很多人称我“技术”,感觉这是不尊重!纠正无果后果断辞职
查看>>
php程序员看过来,这老外是在吐糟你吗?看看你中了几点!
查看>>
为什么说程序员是“培训班出来的”就是鄙视呢?
查看>>
码农吐糟同事:写代码低调点不行么?空格回车键与你有仇吗?
查看>>
阿里p8程序员四年提交6000次代码的确有功,但一次错误让人唏嘘!
查看>>
一道技术问题引起的遐想,最后得出结论技术的本质是多么的朴实!
查看>>