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;
}
```