实验:数据结构(结构体在单链表中的增删改查)

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

// 学生信息结构体

struct Student {

char name[50];

char gender[10];

int student_number;

char hobbies[100];

struct Student* next;

};

// 初始化一个空表

struct Student* initialize() {

return NULL;

}

// 后插法插入学生信息

struct Student* insert(struct Student* head, char name[], char gender[], int student_number, char hobbies[]) {

struct Student* new_student = (struct Student*)malloc(sizeof(struct Student));

strcpy(new_student->name, name);

strcpy(new_student->gender, gender);

new_student->student_number = student_number;

strcpy(new_student->hobbies, hobbies);

new_student->next = NULL;

if (head == NULL) {

return new_student;

}

struct Student* current = head;

while (current->next != NULL) {

current = current->next;

}

current->next = new_student;

return head;

}

// 根据学号对链表节点进行排序

struct Student* sort_by_student_number(struct Student* head) {

// 使用冒泡排序

int swapped;

struct Student* ptr1;

struct Student* lptr = NULL;

if (head == NULL) {

return NULL;

}

do {

swapped = 0;

ptr1 = head;

while (ptr1->next != lptr) {

if (ptr1->student_number > ptr1->next->student_number) {

// 交换节点

struct Student* temp = ptr1;

ptr1 = ptr1->next;

ptr1->next = temp;

swapped = 1;

}

ptr1 = ptr1->next;

}

lptr = ptr1;

} while (swapped);

return head;

}

// 根据姓名或学号顺序插入新创建的学生信息

struct Student* insert_sorted(struct Student* head, char name[], char gender[], int student_number, char hobbies[]) {

struct Student* new_student = (struct Student*)malloc(sizeof(struct Student));

strcpy(new_student->name, name);

strcpy(new_student->gender, gender);

new_student->student_number = student_number;

strcpy(new_student->hobbies, hobbies);

new_student->next = NULL;

if (head == NULL || student_number < head->student_number) {

new_student->next = head;

return new_student;

}

struct Student* current = head;

while (current->next != NULL && current->next->student_number < student_number) {

current = current->next;

}

new_student->next = current->next;

current->next = new_student;

return head;

}

// 根据学号删除学生信息

struct Student* delete_by_student_number(struct Student* head, int student_number) {

if (head == NULL) {

return NULL;

}

if (head->student_number == student_number) {

struct Student* temp = head;

head = head->next;

free(temp);

return head;

}

struct Student* current = head;

while (current->next != NULL && current->next->student_number != student_number) {

current = current->next;

}

if (current->next != NULL) {

struct Student* temp = current->next;

current->next = current->next->next;

free(temp);

}

return head;

}

// 打印所有学生信息

void print_students(struct Student* head) {

struct Student* current = head;

while (current != NULL) {

printf("姓名:%s,性别:%s,学号:%d,兴趣爱好:%s\n", current->name, current->gender, current->student_number, current->hobbies);

current = current->next;

}

}

int main() {

struct Student* head = initialize();

// 示例:插入学生信息

head = insert(head, "张三", "男", 1001, "篮球");

head = insert(head, "李四", "女", 1002, "音乐");

// ... 插入更多学生信息

// 排序

head = sort_by_student_number(head);

// 插入新学生信息

head = insert_sorted(head, "王五", "男", 1003, "游泳");

// 打印所有学生信息

print_students(head);

// 其他操作...

return 0;

}

相关推荐
BreezeJuvenile9 天前
实验二 呼吸灯功能实验
stm32·单片机·嵌入式系统·流水灯·实验
자신을 변화시키다4 个月前
Linux NFS服务器配置
linux·运维·服务器·经验分享·ubuntu·实验
小纭在努力5 个月前
【算法设计与分析】实验——改写二分搜索算法,众数问题(算法分析:主要算法思路),有重复元素的排列问题,整数因子分解问题(算法实现:过程,分析,小结)
数据结构·python·学习·算法·算法设计与分析·实验报告·实验
Stardep5 个月前
Linux下目录递归拷贝的单进程实现
linux·运维·服务器·实验
铸人6 个月前
旋转磁体产生的场-对导航姿态的影响
实验·物理学
Rinai_R6 个月前
xv6-labs-2024 lab2
c语言·操作系统·学习笔记·计算机基础·实验
levitgu8 个月前
西电应用密码学与网络安全实验通关指南
c++·经验分享·安全·ai·密码学·rsa·实验
小伍_Five8 个月前
Linux 环境“从零”部署 MongoDB 6.0:mongosh 安装与数据操作全攻略
数据库·nosql数据库·实验
天外高人9 个月前
实验六 项目二 简易信号发生器的设计与实现 (HEU)
单片机·嵌入式硬件·fpga开发·实验
上理考研周导师10 个月前
【热力学与工程流体力学】流体静力学实验,雷诺实验,沿程阻力实验,丘里流量计流量系数测定,局部阻力系数的测定,稳态平板法测定材料的导热系数λ
实验·流体力学