结构体在C语言中的应用

将军赶路,莫追小兔。                                                                                        

                                                                                                                                               ----小新

一.为什么要使用结构体

        结构体是C语言中的一种重要数据结构,它允许程序员将不同类型的数据组合成一个单一的实体。通过使用结构体,可以提高代码的可读性和可维护性,同时简化复杂数据结构的处理。本文将介绍结构体的基本概念和语法,并给出一些实际应用案例。

二.结构体的用法

        结构体是一种用户自定义的数据类型,可以包含多个不同类型的数据成员。这些成员可以是基本数据类型,指针类型,结构体本身或其他自定义类型。结构体在定义时需要指定其包含的成员变量和成员函数的数量和类型。

      1.定义结构体类型

       首先需要声明结构体类型,在定义结构体变量。 struct结构体名{成员列表;};struct结构体名结构体变量列表。

      2.引用结构体变量

        可以使用原点运算符来访问结构体变量中的成员,如结构体变量名.成员名。

      3.初始化结构体变量

        可以通过以下三种方式进行初始化:顺序初始化、指定初始化、构造函数初始化。

       4.结构体定义明细

//用法
struct 结构体名 {  
    类型1 成员变量名1;  
    类型2 成员变量名2;  
    ...  
    类型n 成员变量名n;  
};

//代码
struct Person {  
    char name[50];  
    int age;  
    char gender;  
};


//使用结构体的基本语法是声明一个结构体变量,并为它的成员变量赋值
struct Person Tom = {"Tom Smith", 30, 'M'};  


//定义指向结构体的指针,以便通过指针访问结构体的成员变量。
struct Person *p = &Tom;  
printf("%s is %d years old and %c\n", p->name, p->age, p->gender);

三.举个例子

    (1)学生信息管理

        在这个案例中,我们将使用结构体来管理学生信息,包括姓名,年龄和成绩等。我们将定义一个名为Student的结构体,然后声明一些Student类型的变量来存储学生信息。

     1.代码
#include <stdio.h>
#include <string.h>

// 定义一个结构体类型,表示学生信息
typedef struct {
    char name[50]; // 学生姓名
    int age;       // 学生年龄
    float score;   // 学生成绩
} Student;

int main() {
    
/***************************************************/
    // 创建一个Student类型的变量stu1//
/***************************************************/
    Student stu1;

    // 为stu1的成员赋值
    strcpy(stu1.name, "张三");
    stu1.age = 20;
    stu1.score = 90.5;

    // 输出stu1的信息
    printf("学生姓名:%s  ", stu1.name);
    printf("学生年龄:%d  ", stu1.age);
    printf("学生成绩:%.2f  \n", stu1.score);


/***************************************************/
    // 使用结构体数组存储多个学生信息//
/***************************************************/
    Student students[3];

    // 为数组中的元素赋值
    strcpy(students[0].name, "李四");
    students[0].age = 21;
    students[0].score = 88.0;

    strcpy(students[1].name, "王五");
    students[1].age = 22;
    students[1].score = 92.5;

    strcpy(students[2].name, "赵六");
    students[2].age = 23;
    students[2].score = 85.0;

    // 输出数组中的学生信息
    for (int i = 0; i < 3; i++) {
        printf("第%d个学生信息:", i + 1);
        printf("学生姓名:%s  ", students[i].name);
        printf("学生年龄:%d  ", students[i].age);
        printf("学生成绩:%.2f  \n", students[i].score);
    }

    return 0;
}
2.结果

        在这个程序中,我们首先定义了一个名为Student的结构体,包含三个成员变量:name,age和score。然后,在main函数中,我们声明了一个包含三个Student结构体的数组stu,并通过循环为每个学生的姓名,年龄和成绩赋值。最后,我们通过另一个循环打印每个学生的信息。

    (2)循环链表

        创建了一个循环链表,其中包含了创建节点、在链表尾部插入节点、遍历链表等基本操作。在遍历链表时,需要注意判断是否是循环链表。另外,需要注意的是,循环链表的头节点可以是任意节点。

    1.代码
#include <stdio.h>  
#include <stdlib.h>  
  
// 定义链表节点结构体  
typedef struct Node {  
    int data;               // 节点存储的数据  
    struct Node* next;       // 指向下一个节点的指针  
} Node;  
  
// 创建节点  
Node* createNode(int data) {  
    Node* newNode = (Node*)malloc(sizeof(Node));  // 分配内存空间  
    newNode->data = data;                           // 设置节点存储的数据  
    newNode->next = NULL;                            // 设置指向下一个节点的指针为NULL  
    return newNode;  
}  
  
// 在链表尾部插入节点  
void insert(Node** head, int data) {  
    Node* newNode = createNode(data);  // 创建新节点  
    if (*head == NULL) {             // 如果链表为空,则将新节点作为头节点  
        *head = newNode;  
    } else {  
        Node* curr = *head;         // 定义指向当前节点的指针  
        while (curr->next != NULL) {  // 遍历到链表尾部  
            curr = curr->next;  
        }  
        curr->next = newNode;       // 将新节点插入到链表尾部  
    }  
}  
  
// 遍历链表并打印节点的数据  
void traverse(Node* head) {  
    Node* curr = head;  // 定义指向当前节点的指针  
    while (curr != NULL) {  // 遍历到链表尾部  
        printf("%d \n", curr->data);  // 打印当前节点的数据  
        curr = curr->next;            // 将指向下一个节点的指针指向下一个节点  
        if (curr == head) {            // 如果指向下一个节点的指针指向头节点,则说明是循环链表  
            break;  
        }  
    }  
}  
  
int main() {  
    Node* head = NULL;  // 定义指向头节点的指针,初始值为NULL  
    insert(&head, 10);   // 在链表尾部插入节点,数据为1  
    insert(&head, 20);   // 在链表尾部插入节点,数据为2  
    insert(&head, 30);   // 在链表尾部插入节点,数据为3  
    traverse(head);      // 遍历链表并打印节点的数据,结果为:1 2 3  
    return 0;  
}
         2.结果

结论  

        结构体是C语言中一种非常有用的数据结构,它允许我们将不同类型的数据组合成一个单一的实体,以便更好地组织和管理数据。通过使用结构体,可以提高代码的可读性和可维护性,简化复杂数据结构的处理。本文介绍了结构体的基本概念和语法,并给出了一个实际应用案例。 

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我来挖坑啦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值