【C语言】指针,结构体,链表

简介: 【C语言】指针,结构体,链表

他们是什么?


相信很多同学刚接触指针、链表的时候头疼的不行,那么今天这篇文章将带你明明白白看懂它的简单!

结构体(struct)是由一系列具有相同类型或不同类型的数据构成的数据集合,叫做结构体。结构体就像一个盒子,什么东西都可以放进去。

1684148043040.jpg

这就是链表,此处通过结构体和指针实现。指针是一种数据类型,用来记录地址,此处用来记录下一个结构体的地址。


//首先知道它的地址,才能从地址从拿到东西。  指针就是用来存放地址的。


//链表其实很简单,链式储存而已。 如下:

//盒子A(地址:1 内容:XX 指针:2)

//盒子B(地址:2 内容:YY 指针:3)

//盒子C(地址:3 内容:KK 指针:NULL)  

//那么可以看到每个盒子是个结构体,每个结构体的指针存放的是下个结构体的地址,

//直到最后一个为NULL,那便是链表的尾部,因为没有下一个结构体了,故没有地址。


//如上:盒子A,B,C就是一个链表,链表就是链式储存而已。


代码具体实现


废话少说:看代码,详细解释

# include<stdio.h>
# include<string.h>
struct person{
  int  id;
  char name[30];
  struct person *next; //定义指针 指针是一种数据类型,用于存储地址。 
};
int main(){
  struct person a,b,c,*head,*p;  //定义结构体指针head、p
  a.id=1;strcpy(a.name,"思");  //字符串赋值通过string库进行copy。 
  b.id=2;strcpy(b.name,"思想");
    c.id=3;strcpy(c.name,"思想学家");
    head=&a;    //将结构体a的地址给到头指针
    a.next=&b;  //结构体b的地址给到a
    b.next=&c;  
    c.next=NULL;  //结构体c是最后一个结构体,故没有下一个结构体的地址能够给到
  p=head;    //我们习惯性用P来表示指针,也可以直接用head,head表示头指针,可头指针只有一个
      //后面的第二第三个指针难道也叫head吗?所以还是需要用p表示吧。
    while(1){
      printf("学号是:%d 姓名是:%s\n",p->id,p->name);
      p=p->next;
      if(p==NULL){
      printf("输出完成");
  }
  }
}


结果输出

1684148019102.jpg

相关文章
|
17天前
|
存储 C语言
【数据结构】手把手教你单链表(c语言)(附源码)
本文介绍了单链表的基本概念、结构定义及其实现方法。单链表是一种内存地址不连续但逻辑顺序连续的数据结构,每个节点包含数据域和指针域。文章详细讲解了单链表的常见操作,如头插、尾插、头删、尾删、查找、指定位置插入和删除等,并提供了完整的C语言代码示例。通过学习单链表,可以更好地理解数据结构的底层逻辑,提高编程能力。
44 4
|
23天前
|
存储 C语言
如何在 C 语言中实现结构体的深拷贝
在C语言中实现结构体的深拷贝,需要手动分配内存并逐个复制成员变量,确保新结构体与原结构体完全独立,避免浅拷贝导致的数据共享问题。具体方法包括使用 `malloc` 分配内存和 `memcpy` 或手动赋值。
30 10
|
22天前
|
存储 大数据 编译器
C语言:结构体对齐规则
C语言中,结构体对齐规则是指编译器为了提高数据访问效率,会根据成员变量的类型对结构体中的成员进行内存对齐。通常遵循编译器默认的对齐方式或使用特定的对齐指令来优化结构体布局,以减少内存浪费并提升性能。
|
27天前
|
编译器 C语言
共用体和结构体在 C 语言中的优先级是怎样的
在C语言中,共用体(union)和结构体(struct)的优先级相同,它们都是用户自定义的数据类型,用于组合不同类型的数据。但是,共用体中的所有成员共享同一段内存,而结构体中的成员各自占用独立的内存空间。
|
27天前
|
存储 C语言
C语言:结构体与共用体的区别
C语言中,结构体(struct)和共用体(union)都用于组合不同类型的数据,但使用方式不同。结构体为每个成员分配独立的内存空间,而共用体的所有成员共享同一段内存,节省空间但需谨慎使用。
|
1月前
|
编译器 C语言 C++
C语言结构体
C语言结构体
25 5
|
17天前
|
C语言
【数据结构】双向带头循环链表(c语言)(附源码)
本文介绍了双向带头循环链表的概念和实现。双向带头循环链表具有三个关键点:双向、带头和循环。与单链表相比,它的头插、尾插、头删、尾删等操作的时间复杂度均为O(1),提高了运行效率。文章详细讲解了链表的结构定义、方法声明和实现,包括创建新节点、初始化、打印、判断是否为空、插入和删除节点等操作。最后提供了完整的代码示例。
37 0
|
1月前
|
编译器 Linux C语言
C语言 之 结构体超详细总结
C语言 之 结构体超详细总结
19 0
|
1月前
|
存储 编译器 Linux
深入C语言:探索结构体的奥秘
深入C语言:探索结构体的奥秘
|
1月前
|
存储 编译器 C语言
c语言回顾-结构体(2)(下)
c语言回顾-结构体(2)(下)
28 0