C++线性表和链表

本文阐述C++相关的链表的定义:

首先线来了解一下typedef

关于typedef的介绍:

先从初级的开始:

整形

typedef int x; // 定义了一个名为x的int类型


结构体

typedef struct { char c; } s; // 定义名为s的struct类型

指针

typedef int *p; //定义了一个名为p的指针类型, 它指向int (中文描述指针好累)

接下来是高级的(注意标识符不一定在最后):
数组

typedef int A[];  // 定义一个名为A的ints数组的类型

函数

typedef int f(); // 定义一个名为f, 参数为空, 返回值为int的函数类型
 
typedef int g(int); // 定义一个名为g, 含一个int参数, 返回值为int行的函数类型

下面附上大部分链表的定义:

#include<iostream>
#include<time.h>
using namespace std;
#define MAX_SIZE 100
#define ERROR -1
#define OK 1
typedef int Status;
typedef int ElemType;
//生成随机数
int GetRandomNumber()
{
    int RandomNumber;
    srand((unsigned)time(NULL));//time()用系统时间初始化种。为rand()生成不同的随机种子。
    RandomNumber = rand() % 100 + 1;//生成1~100随机数
    return RandomNumber;
}
typedef struct Lnode 
{
    ElemType data;
    struct Lnode* next;
}LNode;
//定义先行列表的结构
typedef struct sqlist
{
    ElemType Elem_array[MAX_SIZE];
    int length=0;
}SqList;
//初始化线性列表
SqList* InitializeList() {
    SqList* L;
    for (int i{ 0 }; i < 50; i++) {
        L->Elem_array[i] = GetRandomNumber();
        L->length++;
    }
    return L;
}
//插入线性表  顺序线性表的删除则是相反过程
Status Insert_SqList(SqList* L, int i, ElemType e)
{
    int j;
    if (i<0 || i>L->length - 1) return ERROR;
    if (L->length >= MAX_SIZE)
    {
        cout << "线性表溢出!\n"; return ERROR;
    }
    for (j = L->length; j >= i - 1; --j) {
        L->Elem_array[j + 1] = L->Elem_array[j];
    }
    L->Elem_array[i - 1] = e;
    L->length++;
    return OK;
}
//删除线性表中值为x的第一个节点
Status Locate_Delete_SqList(SqList* L, ElemType x)
{
    int j=0, k;
    while (j<L->length)
    {
        if (L->Elem_array[j] != x) j++;
        else {
            for (k = j; k < L->length - 1; k++) {
                L->Elem_array[k] = L->Elem_array[k + 1];
            }
            L->length--;
            break;
        }
        if (j > L->length) {
            cout << "要删除的元素不存在!\n";
            return ERROR;
        }
        else
        {
            return OK;
        }
    }
}
//建立单链表(头插法)
LNode* creat_LinkList(void)
{
    int data;
    LNode* head, * p;
    head = (LNode*)malloc(sizeof(LNode));
    head->next = NULL;
    while (true)
    {
        cout << "请输入单链表数据(当数据为520时停止输入)" << endl;;
        cin >> data;
        if (data != 520)
        {
            p = (LNode*)malloc(sizeof(LNode));
            p->data = data;
            p->next = head->next;
            head->next = p;
        }
        else
        {
            break;
        }
    }
    return(head);
}
//单链表(尾插法)
LNode* creat_LinkList(void)
{
    int data;
    LNode* head, * p, * q;
    head =q= (LNode*)malloc(sizeof(LNode));
    head->next = NULL;
    while (true)
    {
        cout << "请输入单链表数据(当数据为520时停止输入)" << endl;;
        cin >> data;
        if (data != 520)
        {
            p = (LNode*)malloc(sizeof(LNode));
            p->data = data;
            p->next = q->next;
            q->next = p;
            q = p;
        }
        else
        {
            break;
        }
    }
    return(head);
}
//单链表的插入(插入到第i个节点)
LNode* Insert_LNode(LNode* L, int i, ElemType e)
{
    int j;
    LNode* p, * q;
    p = L->next;
    while (j < i-1 && p!=NULL)
    {
        p = p->next;
        j++;
    }
    if (j != i - 1) cout << "i太大,超出范围!!" << endl;
    else {
        q = (LNode*)malloc(sizeof(LNode));
        q->data = e;
        q->next = p->next;
        p->next = q;
    }
}
//单链表的按值索引删除
void Delete_LinkList(LNode* L, int i)
{
    int j;
    LNode* p,*q;
    p = L; q = L->next;
    while (q->next!=NULL&&j<i)
    {
        p = q;
        q = q->next;
        j++;
    }
    if (j != i) cout << "i太大了" << endl;
    else {
        p->next = q->next; free(q);
    }
}
//删除以L为头节点的单链表值为key的第一个节点
void Delete_LinkList(LNode* L, int i)
{
    LNode* p, * q;
    p = L; q = L->next;
    int j;
    LNode* p,*q;
    p = L; q = L->next;
    while (p->next!=NULL&&p->data!=i)
    {
        p = q;
        q = q->next;
    }
    p->next = q->next;
    free(q);
}
//单链表的合并La 和 Lb 合成Lc,默认两个链表有空的head
LNode* Mergr_LinkList(LNode* La, LNode* Lb)
{
    LNode* Lc, * pa, * pb, * pc, * ptr;
    Lc = La; pc = La; pa = La->next; pb = Lb->next;
    while (pa!=NULL&&pb!=NULL)
    {
        if (pa->data < pb->data)
        {
            pc->next = pa;
            pc = pa;
            pa = pa->next;
        }
        if (pa->data > pb->data)
        {
            pc->next = pb;
            pc = pb;
            pa = pb->next;
        }
        if (pa->data == pb->data)
        {
            pc->next = pa;
            pc = pa;
            pa = pa->next;
            ptr = pb;
            pb = pb->next; free(ptr);
        }
        if (pa != NULL) pc->next = pa;
        else pc->next = pb;
        free(Lb);
    }
    return Lc;
}
//循环列表
LNode* creat_LinkList(void)
{
    int data;
    LNode* head, * p, * q;
    head = q = (LNode*)malloc(sizeof(LNode));
    head->next = NULL;
    while (true)
    {
        cout << "请输入单链表数据(当数据为520时停止输入)" << endl;;
        cin >> data;
        if (data != 520)
        {
            p = (LNode*)malloc(sizeof(LNode));
            p->data = data;
            p->next = q->next;
            q->next = p;
            q = p;
        }
        else
        {
            //首位相连
            p->next = head;
            break;
        }

    }
    return(head);
}
//双向列表的定义
typedef struct Dulnode
{
    ElemType data;
    struct Dulnode* prior, * next;
}DulNode;
//初始化双向列表
DulNode* DulNode_List()
{
    int data;
    DulNode* head, * p, * q;
    head =q = (DulNode*)malloc(sizeof(DulNode));
    head->next = NULL;
    head->prior = NULL;
    while (true)
    {
        cout << "请输入单链表数据(当数据为520时停止输入)" << endl;;
        cin >> data;
        if (data != 520)
        {
            p = (DulNode*)malloc(sizeof(DulNode));
            p->data = data;
            p->next = q->next;
            p->prior = q;
            q->next = p;
            q = p;
        }
        else
        {
            break;
        }
    }
    return(head);
}
int main() {
    SqList* L = InitializeList();

}

 

上一篇:数据结构--链表操作


下一篇:考研复试面试准备——数据结构篇