链表基础,建立,查找,插入,整体删除

本文面向链表初学者,详细解释如何建立带头结点的单向链表,包括使用指针创建链表的过程,并探讨链表的查找、插入操作。文章强调理解每个节点的地址概念,以及在插入时保持链表升序的重要性。

本文是想给对链表基本不是太了解的人准备,这篇文章中的方法都只是最基本的方法,可以在《c语言程序设计》一书中找到,我只是补上了自己的理解帮助没有看懂的小伙伴,链表更难的方法我会在以后补上,一起加油!

链表的建立
建立和输出有若干个学生记录的带头结点的单向链表,用指针类型的函数creat()创建链表,返回链表的头指针,函数中定义了三个指针变量,head为头指针p1指向新节点,p2为尾指针指向尾节点。
算法分析:
先产生头结点,head,p2都指向他,输入他的数据。
产生第一个新节点,p1指向新节点,输入他的数据。
当产生的新节点非0时进入循环,循环中,直接将新节点链接到表尾,再产生新结点,输入数据,学号为0则循环结束。
释放无效结点的存储空间,尾结点指针域置空,反回头指针。

#include <stdio.h>
#include <stdlib.h>        //malloc函数在这个头文件内
#define PT "学号:%ld  姓名:%-10s 成绩:%6.1f\n",p->num,p->name,p->score
#define N sizeof(struct stud)
struct stud *creat(void);
void print(struct stud *p);
struct stud
{
    long num;
    char name[11];
    float score;
    struct stud *next;
};
struct stud *creat(void)                        //这个函数最后返回的是头指针,意思是返回一个指向stud类型的指针
{
    struct stud *p1,*p2,*head;                //定义了三个存放stud类型地址的指针
    head=p2=(struct stud *)malloc(N);           //申请了长度为N的空间,并将分配的存储空间地址转换成stud类型地址         !!!head和p2指向头节点
    printf("请输入学号   姓名    成绩(学号输入零结束)\n");
    p1=(struct stud*)malloc(N);
    scanf("%ld%s%f",&p1->num,p1->name,&p1->score);
    while(p1->num!=0)
    {
        p2->next=p1;                                     //链接下一个节点
        p2=p1;                                                 
        p1=(struct stud *)malloc(N);             //p1指向新节点
        scanf("%ld%s%f",&p1->num,p1->name,&p1->score);
    }
    p2->next==NULL;
    free(p1);
    return head;
}
void print(struct stud *p)
{
    p=p->next;
    while(p!=NULL)
    {                                                            //!!!!!!!!
        printf(PT);
        p=p->next;
    }
}
int main()
{
    struct stud *head;
    head=creat();
    print(head);
    return 0;
}

心得:在理解这个代码时总是因为p1,p2的理解偏差而感觉很绕。一定套注意在每一个节点处都有两个地址,一个是自身地址,一个是内部存的别人的地址,p1,p2的使命就是存这些节点本身的地址,p2->next的意思就是p2所指的结点内存的地址,让他等于下一个节点自身的地址来将他们连起来。

在理解上面的代码后就可以看看以下代码了,自己不要看打一遍!!!
链表的查找(紧接着上面)

struct stud *find(*p)
{
        printf("请输入想查询的学号")scanf("%ld",&num);
        p=p->next;
        while(p!=NULL)
        {
            if(p->num==num)
            {
                return p;                                   //返回的是指向所需结点的指针
            }
            p=p->next;
        }
        return NULL;
}

链表的插入
要求:增加一个插入函数insert().假设所有结点都是按学号的大小升序连接的,插入新节点后仍保持升序,若
新节点的学号与原有某节点的学号相同则不插入。

int  insert(struct stud *p0)
{
    struct stud *p;
    p=(struct stud *)malloc(N);
    printf("请输入要插入的学号 姓名 成绩\n");
    scanf("%ld%s%f\n",&p->num,p->name,&p->score);
    while(p0->next!=NULL&&p0->next->num<p->num)                          //第一次保证头结点内存的值不为NULL,否则是一个空表
    {                                                                                                                     //&&后面意思是(p0所指的结点的下一结点的num)>num,(p0所指的结点的num)<num
        p0=p0->next;
    }
    if(p0->next!=NULL&&p0->next->num==num)
        {
            free(p);
            return 0;
        }
    p->next=p0->next;  //将p0所指后面的节点的地址存到p指的节点中
    p0->next=p;
    return 1;
}

链表的整体删除

void shanchu(struct styd *p)
{
    struct stud *q;
    for(;p;p=q)
    {
        q=p->next;
        free(p);
    }
}
//p=NULL时退出
六自由度机械臂ANN人工神经网络设计:正向逆向运动学求解、正向动力学控制、拉格朗日-欧拉法推导逆向动力学方程(Matlab代码实现)内容概要:本文档围绕六自由度机械臂的ANN人工神经网络设计展开,详细介绍了正向与逆向运动学求解、正向动力学控制以及基于拉格朗日-欧拉法推导逆向动力学方程的理论与Matlab代码实现过程。文档还涵盖了PINN物理信息神经网络在微分方程求解、主动噪声控制、天线分析、电动汽车调度、储能优化等多个工程与科研领域的应用案例,并提供了丰富的Matlab/Simulink仿真资源和技术支持方向,体现了其在多学科交叉仿真与优化中的综合性价值。; 适合人群:具备一定Matlab编程基础,从事机器人控制、自动化、智能制造、电力系统或相关工程领域研究的科研人员、研究生及工程师。; 使用场景及目标:①掌握六自由度机械臂的运动学与动力学建模方法;②学习人工神经网络在复杂非线性系统控制中的应用;③借助Matlab实现动力学方程推导与仿真验证;④拓展至路径规划、优化调度、信号处理等相关课题的研究与复现。; 阅读建议:建议按目录顺序系统学习,重点关注机械臂建模与神经网络控制部分的代码实现,结合提供的网盘资源进行实践操作,并参考文中列举的优化算法与仿真方法拓展自身研究思路。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值