链表部分操作案例

news/2025/2/22 19:15:53

接上一篇 链表:带头节点和不带头结点,还有头指针-CSDN博客

 这个可以做下参考,初步测试没问题了。其他的后面写

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

typedef struct Node{
    int val;
    struct Node *next;    
}Nodes, *Linklist;    //       这个例子中的display函数会将遍历过的链表释放,所以看情况修改就行,仅参考

Linklist makeNode(int val){
    Nodes * newNode = (Nodes *) malloc(sizeof(Nodes));
    newNode->val = val;
    newNode->next = NULL;
    return newNode;
}
Linklist makeHead() {//头结点
    Linklist head = (Linklist)malloc(sizeof(Nodes));
    head->next = NULL;
    return head;
}
Linklist initList(Linklist head, int val) { //头插法
    if(head == NULL){  //一般这样写,只看这个函数中,如果传进来的head是个错误的,或者无效的指针,链表的头结点不存在那也没办法创建链表               //所以判空
        return NULL;
    }
    Linklist newNode = makeNode(val);
    newNode->next = head->next;
    head->next = newNode;
    return head;
}
Linklist deleteAtInedx(Linklist head,int index)  //传入的是头指针,删除固定索引值结点
{
    if(head == NULL || index < 0)
    {
        exit(1);
    } 
    Linklist p = head;
    if(index == 1){
        head = p->next;
        free(p);
        return head;
    }
    int i = 0;
    while( i < index-1 ){
        if(p->next != NULL){
            p=p->next;
        }
        printf("p = %d\n", p->val);
        ++i;
    }
    Linklist tmp = p->next;
    p->next = p->next->next;
    free(tmp);
    return head;
}
void displayList(Linklist head)                //遍历打印链表后,这里是直接将链表释放了。
{
    if(head == NULL) {
        exit(1);
    }
    while(head->next != NULL){
        printf("%d ", head->next->val);
        Linklist p = head->next;
        head->next = head->next->next;
        free(p);
    }
    free(head);
    printf("\n");
}
Linklist insertAtTail(Linklist head, int *arr , int nums)
{
    Linklist tail = head;
    int i = 0;
    while(i < nums)
    {
        Linklist newNode = makeNode(arr[i]);
        tail ->next = newNode;
        tail = newNode;
        ++i;
    }
    return head;

}
Linklist insertAtIndex(Linklist head , int index, int val){
    if(head == NULL || index < 0){             //如果超出链表最大长度,也是可以报错处理的,因为这个案例结构中没有用链表长度,这里不写了
        exit(1);
    }
    Linklist p = head;
    Linklist tmp = makeNode(val);
    for(int i=1; i < index; ++i){
        p = p->next;
    }
    tmp->next = p->next;
    p->next = tmp;
    return head;
}

int main(){

    int arr[] = {1,2,3,4,5,6,7};
    int i = 0;
    Linklist phead = makeHead();
    while(i < sizeof(arr)/sizeof(int)){
        phead = initList(phead,arr[i]);
        i++;
    }
    //displayList(phead);

    //Linklist phead2 =  makeHead();
    //phead2 = insertTail(phead2,arr,sizeof(arr)/sizeof(int));
    //displayList(phead2);              //
    //Linklist phead3 = deleteAtIndex(phead, 1);
    //displayList(phead3);

    Linklist p4 =insertAtIndex(phead, 2, 9);
    displayList(p4);
    printf("p4 的地址是 %p\n", p4);
    return 0;

}


http://www.niftyadmin.cn/n/5315822.html

相关文章

软件测试|Python urllib3库使用指南

简介 当涉及到进行网络请求和处理HTTP相关任务时&#xff0c;Python的urllib3库是一个强大且灵活的选择。它提供了一种简单的方式来执行HTTP请求、处理响应和处理连接池&#xff0c;使得与Web服务进行交互变得更加容易。本文将详细介绍如何使用urllib3库进行网络请求。 安装u…

three.js实现雷达扫描效果(纹理贴图)

three.js实现雷达扫描效果&#xff08;纹理贴图&#xff09; 图例 步骤 创建两个平面&#xff0c;分别纹理贴图&#xff0c;底图模型.add&#xff08;光波模型&#xff09;关闭材质的深度测试光波旋转 代码 <template><div class"app"><div ref&q…

鸿蒙原生应用再添新丁!京东入局鸿蒙

鸿蒙原生应用再添新丁&#xff01;京东入局鸿蒙 来自 HarmonyOS 微博1月10日消息&#xff0c;#京东启动鸿蒙原生应用开发#&#xff01;优惠信息、派送进度都可以随时随地便捷查询。双方将携手为消费者带来全场景“多快好省”购物体验&#xff0c;更智能&#xff0c;更贴心&…

CHS_01.2.1.1+2.1.3+进程的概念、组成、特征

CHS_01.2.1.12.1.3进程的概念、组成、特征 进程进程的概念 进程的组成——PCB进程的组成——PCB进程的组成——程序段、数据段知识滚雪球&#xff1a;程序是如何运行的&#xff1f;进程的组成进程的特征 知识回顾与重要考点 从这个小节开始 我们会正式进入第二章处理机管理相关…

CMU15-445-Spring-2023-Project #2 - 前置知识(lec07-010)

Lecture #07_ Hash Tables Data Structures Hash Table 哈希表将键映射到值。它提供平均 O (1) 的操作复杂度&#xff08;最坏情况下为 O (n)&#xff09;和 O (n) 的存储复杂度。 由两部分组成&#xff1a; Hash Function和Hashing Scheme&#xff08;发生冲突后的处理&…

【笔记】书生·浦语大模型实战营——第三课(基于 InternLM 和 LangChain 搭建你的知识库)

【参考&#xff1a;tutorial/langchain at main InternLM/tutorial】 【参考&#xff1a;(3)基于 InternLM 和 LangChain 搭建你的知识库_哔哩哔哩_bilibili-【OpenMMLab】】 笔记 基础作业 这里需要等好几分钟才行 bug&#xff1a; 碰到pandas相关报错就卸载重装 输出文字…

//一个使用CImage类将彩色jpeg图像转换成灰度图像的小程序

//本小程序使用VS2022编程环境&#xff0c;在C空项目中使用CImage类将彩色jpeg图像转换成灰度图像 //相关代码及注释如下&#xff1a; #include<iostream> #include<atlimage.h> //处理图像类对象必须包含的头文件 #include<string.h> using namespace std;…

6款实用的Git可视化管理工具

前言 俗话说得好“工欲善其事&#xff0c;必先利其器”&#xff0c;合理的选择和使用可视化的管理工具可以降低技术入门和使用门槛。我们在团队开发中统一某个开发工具能够降低沟通成本&#xff0c;提高协作效率。今天给大家分享6款实用的Git可视化管理工具。 Git是什么&…