c语言宿舍管理系统如何定义结构体

时间: 2023-11-07 07:59:32 浏览: 46
定义一个结构体来表示宿舍信息可以使用如下语法: ``` struct Dormitory { int id; // 宿舍编号 int floor; // 宿舍楼层数 int number_of_beds; // 床位数量 char gender; // 宿舍性别限制 }; ``` 这里我们定义了一个包含宿舍编号、宿舍楼层数、床位数量和宿舍性别限制的结构体。可以根据具体需求添加或删除字段。同时,也可以定义一个指向此结构体的指针类型,方便进行操作: ``` typedef struct Dormitory *DormitoryPtr; ```
相关问题

c语言宿舍管理系统代码结构体数组

以下是一个基本的宿舍管理系统的C语言代码,使用结构体数组来存储学生信息和宿舍房间信息: ```c #include <stdio.h> struct Student { char name[20]; int age; char gender; char major[20]; }; struct Room { int roomNumber; int capacity; struct Student students[4]; }; int main() { struct Room rooms[10]; // 有10个宿舍房间 // 初始化每个宿舍房间 for (int i = 0; i < 10; i++) { rooms[i].roomNumber = i+1; rooms[i].capacity = 4; for (int j = 0; j < 4; j++) { struct Student s = {"", 0, ' ', ""}; rooms[i].students[j] = s; } } // 添加学生到宿舍房间 struct Student s1 = {"Tom", 18, 'M', "Computer Science"}; rooms[0].students[0] = s1; struct Student s2 = {"Jerry", 19, 'M', "Mathematics"}; rooms[0].students[1] = s2; struct Student s3 = {"Alice", 20, 'F', "Physics"}; rooms[1].students[0] = s3; // 打印宿舍房间信息 for (int i = 0; i < 10; i++) { printf("Room %d, capacity: %d\n", rooms[i].roomNumber, rooms[i].capacity); for (int j = 0; j < 4; j++) { struct Student s = rooms[i].students[j]; if (s.name[0] != '\0') { printf("Student %d: %s, %d, %c, %s\n", j+1, s.name, s.age, s.gender, s.major); } } } return 0; } ``` 这个程序定义了两个结构体 `Student` 和 `Room`,其中 `Student` 用于存储学生信息,`Room` 用于存储宿舍房间信息。每个 `Room` 结构体中包含一个结构体数组 `students`,用于存储该宿舍房间的学生信息。 在 `main` 函数中,我们定义了一个包含10个 `Room` 结构体的数组 `rooms`,并初始化每个宿舍房间的信息。然后,我们向其中几个宿舍房间添加了一些学生信息,最后打印了每个宿舍房间的信息。 你可以根据自己的需要修改这个程序,并添加其他功能来实现一个完整的宿舍管理系统。

C语言学生宿舍管理系统链表

链表是一种常用的数据结构,可以用来实现学生宿舍管理系统。下面是一个简单的C语言实现,包括添加学生信息、删除学生信息、查询学生信息和显示学生信息等功能。 首先,定义一个结构体来存储学生信息: ```c typedef struct student { char name[20]; // 姓名 char id[10]; // 学号 char gender[5]; // 性别 char dorm[10]; // 宿舍号 struct student *next; // 下一个节点指针 } Student; ``` 然后,定义一个函数来创建新的节点: ```c Student* newNode() { Student *node = (Student*)malloc(sizeof(Student)); printf("请输入学生姓名:"); scanf("%s", node->name); printf("请输入学生学号:"); scanf("%s", node->id); printf("请输入学生性别(男/女):"); scanf("%s", node->gender); printf("请输入学生宿舍号:"); scanf("%s", node->dorm); node->next = NULL; return node; } ``` 接下来,定义一个函数来添加新节点: ```c void addNode(Student **head) { Student *node = newNode(); if (*head == NULL) { // 如果链表为空 *head = node; // 直接将新节点作为头结点 } else { Student *p = *head; while (p->next != NULL) { // 找到链表的尾节点 p = p->next; } p->next = node; // 将新节点添加到尾部 } printf("添加成功!\n"); } ``` 然后,定义一个函数来删除节点: ```c void deleteNode(Student **head, char *id) { if (*head == NULL) { // 如果链表为空 printf("没有找到该学生!\n"); return; } Student *p = *head; if (strcmp((*head)->id, id) == 0) { // 如果要删除的节点是头结点 *head = (*head)->next; free(p); printf("删除成功!\n"); return; } while (p->next != NULL && strcmp(p->next->id, id) != 0) { // 找到要删除的节点 p = p->next; } if (p->next == NULL) { // 如果没有找到 printf("没有找到该学生!\n"); return; } Student *q = p->next; p->next = q->next; // 删除节点 free(q); printf("删除成功!\n"); } ``` 接下来,定义一个函数来查询节点: ```c void searchNode(Student *head, char *id) { if (head == NULL) { // 如果链表为空 printf("没有找到该学生!\n"); return; } Student *p = head; while (p != NULL && strcmp(p->id, id) != 0) { // 找到要查询的节点 p = p->next; } if (p == NULL) { // 如果没有找到 printf("没有找到该学生!\n"); return; } printf("姓名:%s\t学号:%s\t性别:%s\t宿舍号:%s\n", p->name, p->id, p->gender, p->dorm); } ``` 最后,定义一个函数来显示所有节点: ```c void display(Student *head) { if (head == NULL) { // 如果链表为空 printf("链表为空!\n"); return; } Student *p = head; while (p != NULL) { printf("姓名:%s\t学号:%s\t性别:%s\t宿舍号:%s\n", p->name, p->id, p->gender, p->dorm); p = p->next; } } ``` 完整代码如下: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct student { char name[20]; // 姓名 char id[10]; // 学号 char gender[5]; // 性别 char dorm[10]; // 宿舍号 struct student *next; // 下一个节点指针 } Student; Student* newNode() { Student *node = (Student*)malloc(sizeof(Student)); printf("请输入学生姓名:"); scanf("%s", node->name); printf("请输入学生学号:"); scanf("%s", node->id); printf("请输入学生性别(男/女):"); scanf("%s", node->gender); printf("请输入学生宿舍号:"); scanf("%s", node->dorm); node->next = NULL; return node; } void addNode(Student **head) { Student *node = newNode(); if (*head == NULL) { // 如果链表为空 *head = node; // 直接将新节点作为头结点 } else { Student *p = *head; while (p->next != NULL) { // 找到链表的尾节点 p = p->next; } p->next = node; // 将新节点添加到尾部 } printf("添加成功!\n"); } void deleteNode(Student **head, char *id) { if (*head == NULL) { // 如果链表为空 printf("没有找到该学生!\n"); return; } Student *p = *head; if (strcmp((*head)->id, id) == 0) { // 如果要删除的节点是头结点 *head = (*head)->next; free(p); printf("删除成功!\n"); return; } while (p->next != NULL && strcmp(p->next->id, id) != 0) { // 找到要删除的节点 p = p->next; } if (p->next == NULL) { // 如果没有找到 printf("没有找到该学生!\n"); return; } Student *q = p->next; p->next = q->next; // 删除节点 free(q); printf("删除成功!\n"); } void searchNode(Student *head, char *id) { if (head == NULL) { // 如果链表为空 printf("没有找到该学生!\n"); return; } Student *p = head; while (p != NULL && strcmp(p->id, id) != 0) { // 找到要查询的节点 p = p->next; } if (p == NULL) { // 如果没有找到 printf("没有找到该学生!\n"); return; } printf("姓名:%s\t学号:%s\t性别:%s\t宿舍号:%s\n", p->name, p->id, p->gender, p->dorm); } void display(Student *head) { if (head == NULL) { // 如果链表为空 printf("链表为空!\n"); return; } Student *p = head; while (p != NULL) { printf("姓名:%s\t学号:%s\t性别:%s\t宿舍号:%s\n", p->name, p->id, p->gender, p->dorm); p = p->next; } } int main() { Student *head = NULL; int choice; char id[10]; while (1) { printf("1. 添加学生信息\n"); printf("2. 删除学生信息\n"); printf("3. 查询学生信息\n"); printf("4. 显示所有学生信息\n"); printf("5. 退出\n"); printf("请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: addNode(&head); break; case 2: printf("请输入要删除的学生学号:"); scanf("%s", id); deleteNode(&head, id); break; case 3: printf("请输入要查询的学生学号:"); scanf("%s", id); searchNode(head, id); break; case 4: display(head); break; case 5: exit(0); default: printf("输入错误,请重新选择!\n"); break; } } return 0; } ```

相关推荐

最新推荐

recommend-type

基于C/C++开发的单目控制机械臂的上位机程序+视觉识别和关节角反解+源码(高分优秀项目)

基于C/C++开发的单目控制机械臂的上位机程序+视觉识别和关节角反解+源码,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用~ 基于C/C++开发的单目控制机械臂的上位机程序+视觉识别和关节角反解+源码,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用~ 基于C/C++开发的单目控制机械臂的上位机程序+视觉识别和关节角反解+源码,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用~ 基于C/C++开发的单目控制机械臂的上位机程序+视觉识别和关节角反解+源码,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用~
recommend-type

setuptools-68.2.1-py3-none-any.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

springboot 学生信息管理系统.zip

学生管理系统是一个典型的基于 Spring Boot 的应用程序,旨在帮助学校、教育机构或培训机构管理学生信息、课程安排、成绩等。下面我将介绍一个简单的学生管理系统的设计和实现,基于 Spring Boot 框架。 功能特点 学生信息管理 添加、编辑、删除学生信息。 查询学生信息,支持按姓名、学号等条件查询。
recommend-type

setuptools-0.9.8-py2.py3-none-any.whl

Python库是一组预先编写的代码模块,旨在帮助开发者实现特定的编程任务,无需从零开始编写代码。这些库可以包括各种功能,如数学运算、文件操作、数据分析和网络编程等。Python社区提供了大量的第三方库,如NumPy、Pandas和Requests,极大地丰富了Python的应用领域,从数据科学到Web开发。Python库的丰富性是Python成为最受欢迎的编程语言之一的关键原因之一。这些库不仅为初学者提供了快速入门的途径,而且为经验丰富的开发者提供了强大的工具,以高效率、高质量地完成复杂任务。例如,Matplotlib和Seaborn库在数据可视化领域内非常受欢迎,它们提供了广泛的工具和技术,可以创建高度定制化的图表和图形,帮助数据科学家和分析师在数据探索和结果展示中更有效地传达信息。
recommend-type

利用python的pyautogui函数实现简单的自动化操作

1.安装python3.4以上版本,并配置环境变量(目前有装3.9遇到坑的,我个人用的3.7.6) 教程:https://www.runoob.com/python3/python3-install.html 2.安装依赖包 方法:在cmd中(win+R 输入cmd 回车)输入 pip install pyperclip 回车 pip install xlrd 回车 pip install pyautogui==0.9.50 回车 pip install opencv-python -i https://pypi.tuna.tsinghua.edu.cn/simple 回车 pip install pillow 回车 这几步如果哪步没成功,请自行百度 如 pip install opencv-python失败 3.把每一步要操作的图标、区域截图保存至本文件夹 png格式(注意如果同屏有多个相同图标,回默认找到最左上的一个,因此怎么截图,截多大的区域,是个学问,如输入框只截中间空白部分肯定是不行的,宗旨就是“唯一”) 4.在cmd.xls 的sheet1 中,配置每一步的指令,如指
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。