用C语言编写一个学生宿舍管理系统
时间: 2023-03-13 17:20:57 浏览: 170
我可以为你提供一些建议,但最终还是要依赖于你自己的编程能力。首先,你可以利用C语言的函数和数据结构来编写程序,比如定义学生宿舍管理系统的实体,包括学生,宿舍,房间等。其次,你可以利用C语言的流程控制语句,如if语句、while语句等,来控制程序的流程。最后,你可以利用I/O函数,比如fopen()函数,来实现学生宿舍管理系统的输入输出功能。
相关问题
用C语言编写一个学生宿舍管理系统大约两百行
以下是一个简单的学生宿舍管理系统,共计约200行C语言代码:
```c
#include <stdio.h>
#include <string.h>
#define MAX_STUDENT 100 // 最大学生人数
#define MAX_NAME_LENGTH 20 // 学生姓名最大长度
#define MAX_ROOM 10 // 最大房间数
// 学生结构体
struct Student {
char name[MAX_NAME_LENGTH]; // 姓名
int roomNumber; // 房间号
};
// 学生数组
struct Student students[MAX_STUDENT];
int studentCount = 0;
// 房间数组
int rooms[MAX_ROOM];
void printMenu() {
printf("\n");
printf("1. 添加学生\n");
printf("2. 删除学生\n");
printf("3. 查询学生\n");
printf("4. 显示所有学生\n");
printf("5. 分配房间\n");
printf("6. 退房\n");
printf("7. 退出程序\n");
printf("\n");
}
void addStudent() {
if (studentCount == MAX_STUDENT) {
printf("学生人数已满,无法添加新学生!\n");
return;
}
struct Student student;
printf("请输入学生姓名:");
scanf("%s", student.name);
student.roomNumber = 0; // 初始房间号为0
students[studentCount] = student;
studentCount++;
printf("添加学生成功!\n");
}
void deleteStudent() {
char name[MAX_NAME_LENGTH];
printf("请输入要删除的学生姓名:");
scanf("%s", name);
int index = -1;
for (int i = 0; i < studentCount; i++) {
if (strcmp(students[i].name, name) == 0) {
index = i;
break;
}
}
if (index == -1) {
printf("未找到该学生!\n");
return;
}
// 将最后一个学生移到要删除的位置
students[index] = students[studentCount - 1];
studentCount--;
printf("删除学生成功!\n");
}
void queryStudent() {
char name[MAX_NAME_LENGTH];
printf("请输入要查询的学生姓名:");
scanf("%s", name);
int index = -1;
for (int i = 0; i < studentCount; i++) {
if (strcmp(students[i].name, name) == 0) {
index = i;
break;
}
}
if (index == -1) {
printf("未找到该学生!\n");
return;
}
printf("姓名:%s,房间号:%d\n", students[index].name, students[index].roomNumber);
}
void showAllStudents() {
printf("所有学生信息:\n");
for (int i = 0; i < studentCount; i++) {
printf("姓名:%s,房间号:%d\n", students[i].name, students[i].roomNumber);
}
}
void allocateRoom() {
int roomNumber;
printf("请输入要分配的房间号:");
scanf("%d", &roomNumber);
if (roomNumber <= 0 || roomNumber > MAX_ROOM) {
printf("房间号无效!\n");
return;
}
// 检查房间是否已被分配
for (int i = 0; i < studentCount; i++) {
if (students[i].roomNumber == roomNumber) {
printf("该房间已被分配!\n");
return;
}
}
// 将学生分配到房间
for (int i = 0; i < studentCount; i++) {
if (students[i].roomNumber == 0) {
students[i].roomNumber = roomNumber;
printf("分配成功!\n");
return;
}
}
printf("没有空闲的床位了!\n");
}
void leaveRoom() {
int roomNumber;
printf("请输入要退房的房间号:");
scanf("%d", &roomNumber);
int index = -1;
for (int i = 0; i < studentCount; i++) {
if (students[i].roomNumber == roomNumber) {
index = i;
break;
}
}
if (index == -1) {
printf("未找到该房间或该房间未被分配!\n");
return;
}
students[index].roomNumber = 0;
printf("退房成功!\n");
}
int main() {
// 初始化房间数组
for (int i = 0; i < MAX_ROOM; i++) {
rooms[i] = i + 1;
}
while (1) {
printMenu();
int choice;
printf("请选择操作:");
scanf("%d", &choice);
switch (choice) {
case 1:
addStudent();
break;
case 2:
deleteStudent();
break;
case 3:
queryStudent();
break;
case 4:
showAllStudents();
break;
case 5:
allocateRoom();
break;
case 6:
leaveRoom();
break;
case 7:
printf("程序已退出。\n");
return 0;
default:
printf("无效的操作!\n");
break;
}
}
return 0;
}
```
该程序实现了以下功能:
1. 添加学生
2. 删除学生
3. 查询学生
4. 显示所有学生
5. 分配房间
6. 退房
7. 退出程序
程序使用结构体来存储学生信息,同时使用一个数组来存储所有学生。房间信息则使用一个简单的整型数组来存储。在分配房间时,程序会检查房间是否已被分配,并将学生分配到第一个空闲的床位。在退房时,程序会将学生的房间号设为0,表示该学生已离开宿舍。
使用c语言编写一个学生宿舍管理系统,且包含折半查找和线性查找
下面是一个简单的学生宿舍管理系统的 C 语言代码示例,包含了折半查找和线性查找两种查找方式。该系统可以实现添加、删除、查找和修改学生信息等基本功能。
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_STUDENT_NUM 100 // 最大学生数
#define MAX_NAME_LEN 20 // 最大姓名长度
#define MAX_ROOM_NUM 5 // 最大房间数
#define MAX_BED_NUM 4 // 最大床位数
// 学生信息结构体
typedef struct {
char name[MAX_NAME_LEN];
int room_num;
int bed_num;
} Student;
// 学生数组和学生数
Student students[MAX_STUDENT_NUM];
int student_num = 0;
// 折半查找函数
int binary_search(char name[]) {
int left = 0, right = student_num - 1;
while (left <= right) {
int mid = (left + right) / 2;
if (strcmp(students[mid].name, name) == 0) {
return mid;
} else if (strcmp(students[mid].name, name) < 0) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return -1;
}
// 线性查找函数
int linear_search(char name[]) {
for (int i = 0; i < student_num; i++) {
if (strcmp(students[i].name, name) == 0) {
return i;
}
}
return -1;
}
// 添加学生信息函数
void add_student() {
if (student_num >= MAX_STUDENT_NUM) {
printf("学生数已达上限\n");
return;
}
printf("请输入学生姓名:");
scanf("%s", students[student_num].name);
printf("请输入房间号(1-%d):", MAX_ROOM_NUM);
scanf("%d", &students[student_num].room_num);
printf("请输入床位号(1-%d):", MAX_BED_NUM);
scanf("%d", &students[student_num].bed_num);
student_num++;
printf("学生信息添加成功\n");
}
// 删除学生信息函数
void delete_student() {
char name[MAX_NAME_LEN];
printf("请输入要删除的学生姓名:");
scanf("%s", name);
int index = binary_search(name);
if (index == -1) {
printf("未找到该学生\n");
} else {
for (int i = index; i < student_num - 1; i++) {
students[i] = students[i + 1];
}
student_num--;
printf("学生信息删除成功\n");
}
}
// 查找学生信息函数
void find_student() {
char name[MAX_NAME_LEN];
printf("请输入要查找的学生姓名:");
scanf("%s", name);
int index = binary_search(name);
if (index == -1) {
printf("未找到该学生\n");
} else {
printf("姓名:%s,房间号:%d,床位号:%d\n", students[index].name,
students[index].room_num, students[index].bed_num);
}
}
// 修改学生信息函数
void modify_student() {
char name[MAX_NAME_LEN];
printf("请输入要修改的学生姓名:");
scanf("%s", name);
int index = binary_search(name);
if (index == -1) {
printf("未找到该学生\n");
} else {
printf("请输入新的房间号(1-%d):", MAX_ROOM_NUM);
scanf("%d", &students[index].room_num);
printf("请输入新的床位号(1-%d):", MAX_BED_NUM);
scanf("%d", &students[index].bed_num);
printf("学生信息修改成功\n");
}
}
// 显示所有学生信息函数
void display_all_students() {
printf("所有学生信息如下:\n");
for (int i = 0; i < student_num; i++) {
printf("姓名:%s,房间号:%d,床位号:%d\n", students[i].name,
students[i].room_num, students[i].bed_num);
}
}
// 主函数
int main() {
int choice;
while (1) {
printf("\n");
printf("1. 添加学生信息\n");
printf("2. 删除学生信息\n");
printf("3. 查找学生信息\n");
printf("4. 修改学生信息\n");
printf("5. 显示所有学生信息\n");
printf("6. 退出系统\n");
printf("请输入你的选择(1-6):");
scanf("%d", &choice);
switch (choice) {
case 1:
add_student();
break;
case 2:
delete_student();
break;
case 3:
find_student();
break;
case 4:
modify_student();
break;
case 5:
display_all_students();
break;
case 6:
exit(0);
default:
printf("输入有误,请重新输入\n");
break;
}
}
return 0;
}
```
该程序使用折半查找和线性查找两种方式实现了学生信息的查找功能。用户可以选择添加、删除、查找和修改学生信息等操作,也可以显示所有学生信息。该程序中还使用了结构体、数组和循环等基本语法,是一个适合初学者练习的项目。
阅读全文