【考研数据结构预习】链表篇

本文分享了使用C语言创建链表的过程与经验,详细介绍了链表的基本操作,并附带了完整的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下学期就要大三,还真的是很快呀!准备报考深圳大学的计算机专业,本人不是科班出身的。今天开始复习数据结构吧!

下面是我的一些个人复习总结,献丑了,有错的请留言指出,十分感谢赏脸了!

链表的创建


一些基本的操作


附上个人的链表创建代码(C语言)

#include <stdio.h>
#include <stdlib.h>
/*创建节点的数据类型*/
struct stu
{
    int num;
    char name[10];
    struct stu*next;
};
typedef struct stu List;
/*
函数功能:传入节点个数,创建链表,返回头指针
*/
List* createlink(int n)
{
    List*h,*p1,*p2;
    int i;
    int m=n-1;
    h=(List*)malloc(sizeof(List));
    h->next=NULL;
    p1=h;
    printf("请输入第1个学生的学号:");
    scanf("%d",&h->num);
    printf("请输入第1个学生的姓名:");
    scanf("%s",&h->name);
    for(i=0;i<m;i++)
    {
        p2=(List*)malloc(sizeof(List));
	printf("请输入第%d个学生的学号:",i+2);
	scanf("%d",&p2->num);
	printf("请输入第%d个学生的姓名:",i+2);
	scanf("%s",&p2->name);
	p1->next=p2;
	p2->next=NULL;
	p1=p2;
    }
	return h;
}

/*main函数,作为测试用的*/
void main()
{
    List*p;
    int n=0;
    int i=1;
    printf("请输入学生个数:");
    scanf("%d",&n);
    p=createlink(n);
    while(p)
    {
	printf("第%d个学生的学号为:%d,姓名为:%s",i,p->num,p->name);
	p=p->next;  
	i++;
	printf("\n");          
    }
}

有图有真相


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值