[数据结构]线性表1 C++编程作业

链表三插法详解:

链表的三种插入方法(头插法,尾插法,任意位置插入)_链表插入_夜路难行々的博客-CSDN博客

1·使用头插法创建链表

cpp 复制代码
#include <iostream>
using namespace std;

typedef struct Lnode{
    int data;
    struct Lnode *next;
}LNode,*LinkList;

void PrintList(LinkList &L)
{
    LinkList p=L->next;
    while(p){
        cout<<p->data<<" ";
        p=p->next;
    }
    cout<<endl;
}
void CreateList_F(LinkList &L,int n){ 
      L=new LNode; 
      L->next=NULL; //先建立一个带头结点的单链表 
      for(int i=0;i<n;i++){ 
        LNode *p=new LNode; //生成新结点 
        cin>>p->data; //输入元素值 
        p->next=L->next;L->next=p; 	//插入到表头 
     } 
}
int main()
{
    int n;
    cin >> n;
    LinkList L;
    CreateList_F(L,n);
    PrintList(L);
}

2·使用尾插法创建链表

cpp 复制代码
#include <iostream>
using namespace std;

typedef struct Lnode{
    int data;
    struct Lnode *next;
}LNode,*LinkList;

void PrintList(LinkList &L)
{
    LinkList p=L->next;
    while(p){
        cout<<p->data<<" ";
        p=p->next;
    }
    cout<<endl;
}

void CreateList_L(LinkList &L,int n){ 
      L=new LNode; 
      L->next=NULL; 	
      LinkList r=L; 	                                //尾指针r指向头结点 
      for(int i=0;i<n;++i){ 
        LNode *p=new LNode;            //生成新结点 
        cin>>p->data;   		       //输入元素值 
        p->next=NULL; r->next=p;       //插入到表尾 
        r=p; 	                                  //r指向新的尾结点 
      } 
}
int main()
{
    int n;
    cin >> n;
    LinkList L;
    CreateList_L(L,n);
    PrintList(L);
}

3·使用尾插法创建链表并实现删除指定元素

cpp 复制代码
#include <iostream>
using namespace std;

typedef struct Lnode{
    int data;
    struct Lnode *next;
}LNode,*LinkList;

void PrintList(LinkList &L)
{
    LinkList p=L->next;
    while(p){
        cout<<p->data<<" ";
        p=p->next;
    }
    cout<<endl;
}

void CreateList_L(LinkList &L,int n){ 
      //正位序输入n个元素的值,建立带表头结点的单链表L 
      L=new LNode; 
      L->next=NULL; 	
      LinkList r=L; 	                                //尾指针r指向头结点 
      for(int i=0;i<n;++i){ 
        LNode *p=new LNode;            //生成新结点 
        cin>>p->data;   		       //输入元素值 
        p->next=NULL; r->next=p;       //插入到表尾 
        r=p; 	                                  //r指向新的尾结点 
      } 
}//CreateList_L

 bool ListDelete(LinkList &L,int e){
    LinkList p=L->next;
    LinkList q=L;

    while(p && p->data!=e){                 
        q=p;
        p=p->next;
        
    } 
    if(!p) return false; //没找到被删除元素 

    q->next=p->next; 	                  
    delete p;
    return true; 
}//ListDelete
int main()
{
    int n;
    cin >> n;
    LinkList L;
    CreateList_L(L,n);
    int e;
    cin >> e;
    ListDelete(L,e);
    PrintList(L);
  
    return 0;
}

4·合并两个有序链表

cpp 复制代码
#include <iostream>
using namespace std;

typedef struct Lnode{
    int data;
    struct Lnode *next;
}LNode,*LinkList;

void PrintList(LinkList &L)
{
    LinkList p=L->next;
    while(p){
        cout<<p->data<<" ";
        p=p->next;
    }
    cout<<endl;
}

void CreateList_L(LinkList &L,int n){ 
      //正位序输入n个元素的值,建立带表头结点的单链表L 
      L=new LNode; 
      L->next=NULL; 	
      LinkList r=L; 	                                //尾指针r指向头结点 
      for(int i=0;i<n;++i){ 
        LNode *p=new LNode;            //生成新结点 
        cin>>p->data;   		       //输入元素值 
        p->next=NULL; r->next=p;       //插入到表尾 
        r=p; 	                                  //r指向新的尾结点 
      } 
}//CreateList_L
void MergeList_L(LinkList &La,LinkList &Lb,LinkList &Lc){
   LinkList pa=La->next;  
   LinkList pb=Lb->next;
   LinkList pc=Lc=La;                    //用La的头结点作为Lc的头结点 
   while(pa && pb){
      if(pa->data<=pb->data)
        { pc->next=pa;pc=pa;pa=pa->next;}
      else
        {pc->next=pb; pc=pb; pb=pb->next;}
   }
   pc->next=pa?pa:pb;      //插入剩余段  
   delete Lb;                     //释放Lb的头结点}  
}
int main()
{
    int n;
    cin >> n;
    LinkList La;
    CreateList_L(La,n);

    int m;
    cin >> m;
    LinkList Lb;
    CreateList_L(Lb,m);


    LinkList Lc;
    MergeList_L(La,Lb,Lc);
    PrintList(Lc);
    return 0;
}
相关推荐
武子康2 分钟前
大数据-212 数据挖掘 机器学习理论 - 无监督学习算法 KMeans 基本原理 簇内误差平方和
大数据·人工智能·学习·算法·机器学习·数据挖掘
passer__jw76731 分钟前
【LeetCode】【算法】283. 移动零
数据结构·算法·leetcode
Ocean☾37 分钟前
前端基础-html-注册界面
前端·算法·html
顶呱呱程序1 小时前
2-143 基于matlab-GUI的脉冲响应不变法实现音频滤波功能
算法·matlab·音视频·matlab-gui·音频滤波·脉冲响应不变法
爱吃生蚝的于勒1 小时前
深入学习指针(5)!!!!!!!!!!!!!!!
c语言·开发语言·数据结构·学习·计算机网络·算法
羊小猪~~1 小时前
数据结构C语言描述2(图文结合)--有头单链表,无头单链表(两种方法),链表反转、有序链表构建、排序等操作,考研可看
c语言·数据结构·c++·考研·算法·链表·visual studio
王哈哈^_^2 小时前
【数据集】【YOLO】【VOC】目标检测数据集,查找数据集,yolo目标检测算法详细实战训练步骤!
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·pyqt
星沁城2 小时前
240. 搜索二维矩阵 II
java·线性代数·算法·leetcode·矩阵
脉牛杂德2 小时前
多项式加法——C语言
数据结构·c++·算法
legend_jz2 小时前
STL--哈希
c++·算法·哈希算法