数据结构练习:链表扩容

大致步骤:

一:创建一个新链表,遍历原链表的同时,将原链表的值复制给新链表

二:将新链表插入到原链表中(大致如下)

注:

1.头结点是不存有数据的

2.记得malloc后要free

3.*&是c++的写法,等同于c中的*

答案:

复制代码
#define _CRT_SECURE_NO_WARNINGS 1  

#include <stdio.h>  
#include <stdlib.h>
#include <assert.h>  

#define SIZE 100  

typedef int ElemType;

typedef struct LNode {
    ElemType data;
    struct LNode* next;
} LinkNode;

void CreateListR(LinkNode*& L, ElemType a[], int n) {
    LinkNode* s, * r;
    L = (LinkNode*)malloc(sizeof(LinkNode));
    L->next = NULL;
    r = L;
    for (int i = 0; i < n; i++) {
        s = (LinkNode*)malloc(sizeof(LinkNode));
        s->data = a[i];
        r->next = s;
        r = s;
    }
    r->next = NULL;
}

void DispList(LinkNode* L) {
    LinkNode* p = L->next;
    while (p != NULL) {
        printf("%d ", p->data);
        p = p->next;
    }
    printf("\n");
}

void listExpansion(LinkNode*& L) 
{
    assert(L!=NULL);   //避免传进空指针
    LinkNode* l = L;
    LinkNode* p= (LinkNode*)malloc(sizeof(LinkNode));   //建立一个新链表
    p->next = NULL;
    LinkNode* p1 = p;   //复制新链表的头结点
    while (l != NULL)       //将原链表的值复制给新链表
    {
        LinkNode*s= (LinkNode*)malloc(sizeof(LinkNode));
        s->data = l->next->data;
        p1->next = s;
        l = l->next;
        p1 = p1->next;
        if (l->next == NULL)        //如果复制到最后一个结点就break
        {
            break;
        }
    }
    p1 = NULL;      //末尾接上NULL
    l = L->next;      //复制旧链表的头结点
    p1 = p->next;     //复制新链表的头结点
    while (l!=NULL)      //将新链表插入到原链表
    {
        LinkNode* l1 = l->next;
        LinkNode* p2 = p1->next;
        l->next = p1;
        p1->next = l1;
        p1 = p2;
        l = l1;
    }
}

int main() {
    int a[SIZE];
    int n, i;
    scanf("%d", &n);
    for (i = 0; i < n; i++) {
        scanf("%d", &a[i]);
    }

    LinkNode* p;
    CreateListR(p, a, n);

    listExpansion(p);
    // 释放链表内存  
    DispList(p);
    LinkNode* temp;
    while (p != NULL) {    //归还申请空间
        temp = p;
        p = p->next;
        free(temp);
    }
    return 0;
}
相关推荐
2401_891482175 小时前
多平台UI框架C++开发
开发语言·c++·算法
88号技师5 小时前
2026年3月中科院一区SCI-贝塞尔曲线优化算法Bezier curve-based optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
t198751285 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab
无敌昊哥战神5 小时前
【LeetCode 257】二叉树的所有路径(回溯法/深度优先遍历)- Python/C/C++详细题解
c语言·c++·python·leetcode·深度优先
㓗冽6 小时前
8皇后·改-进阶题16
数据结构
x_xbx6 小时前
LeetCode:148. 排序链表
算法·leetcode·链表
Darkwanderor6 小时前
三分算法的简单应用
c++·算法·三分法·三分算法
2401_831920746 小时前
分布式系统安全通信
开发语言·c++·算法
WolfGang0073217 小时前
代码随想录算法训练营 Day17 | 二叉树 part07
算法
温九味闻醉7 小时前
关于腾讯广告算法大赛2025项目分析1 - dataset.py
人工智能·算法·机器学习