单向链表的基本运算

Posted xiaokessy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了单向链表的基本运算相关的知识,希望对你有一定的参考价值。

//

//  main.cpp

//  单向链表的基本运算

//  Created by 柯木超 on 2018/11/27.

//  Copyright ? 2018 柯木超. All rights reserved.

//

#include <iostream> 

typedef struct Node{

    int data;

    struct Node *next;

}linkNode, *link;

 

link createNode() {

    

    // 先声明,然后再赋值, T记录头节点,M 记录当前移动节点,P是当前输入节点

    link T,P,M;

    

    // 1、给头节点开辟新的内存空间

    T = (link)(malloc(sizeof(linkNode)));

    M = T;

    for (int a=0;a<10;a++) {

        P = (link)(malloc(sizeof(linkNode)));

        P->data = a;

        P->next = NULL;

        M->next = P;

        M = P; //M记录当前移动节点

    }

    return T;

}

 

link insertNumber(int data,int number, link L) {

    int length = 0;

    // 获取当前链表长度

    link m = L;

    while (m->next!=NULL) {

        length = length+1;

        m = m->next;

    }    

    if (number >= length){

        printf("插入位置超出链表总长度");

    }else {

        int i = 0;

        while (i < number) {

            L = L->next;

            i = i+1;

        }

        link next = L->next;

        link newNode = (link)malloc(sizeof(linkNode));

        newNode->data = data;

        L->next = newNode; // 断开链表插入新的节点

        newNode->next = next; //和新的节点重新连接

    }

    return L;

}

 

link deleteNumber(int number, link L) {

    int length = 0;

    // 获取当前链表长度

    link m = L;

    while (m->next!=NULL) {

        length = length+1;

        m = m->next;

    }

    if (number >= length){

        printf("删除位置超出链表总长度");

    }else {

        int i = 0;

        while (i < number) {

            L = L->next;

            i = i+1;

        }

        link next = L->next;

        L->next = next->next;

        free(next);

    }

    return L;

}

 

void printNode(link L){

    while (L->next != NULL) {

        L = L->next;

        printf("%d", L->data);

    }

    printf(" ");

}

 

int main(int argc, const char * argv[]) {

    // 创建链表

    link L;

    L = createNode();

    // 打印链表

    printNode(L);

    // 插入数据

    insertNumber(100, 4, L);

    // 打印链表

    printNode(L);

    // 删除数据

    deleteNumber(4, L);

    // 打印链表

    printNode(L);

    return 0;

}

 

以上是关于单向链表的基本运算的主要内容,如果未能解决你的问题,请参考以下文章

线性表之单向链表的基本操作实现

链表1:单向链表的基本操作

单向链表

单向链表的基本操作

单向链表的构建以及翻转算法_图文详解

JavaScript数据结构与算法 单向链表