数据结构课程设计-宿舍管理查询软件-(C/C++)

这篇具有很好参考价值的文章主要介绍了数据结构课程设计-宿舍管理查询软件-(C/C++)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1. 系统需求分析

     1.1 设计理由与意义

     1.2 功能需求分析

     1.3 数据需求分析

2. 系统设计

      2.1 数据结构类型设计

      2.2 整体功能结构设计

     2.3 子模块详细设计

      2.4 程序流程图设计

3.系统实现

      3.1 系统源代码

4.运行效果截图(部分)

5.写在最后 


1. 系统需求分析

     1.1 设计理由与意义

       宿舍管理查询软件是一个教育单位不可缺少的部分它的内容对于学校的决策者和管理者来说都至关重要所以宿舍管理查询软件应该能够为用户提供充足的信息和快捷的查询手段。以前各个学校的学生宿舍管理基本上都是靠手工进行,但随着各个学校的规模增大,有关学生宿舍管理工作所涉及的数据量也越来越大,有的学校不得不靠增加人力、物力来进行学生宿舍管理。这种管理方式存在着许多缺点,如:效率低、保密性差等,另外其所用时间长,产生大量的文件和数据,这对于查找、更新和维护都带来了不少的困难。如今学校的学生越来越多,宿舍管理的工作量越来越大,手工管理宿舍信息的弊端也越来越明显。作为计算机应用的一部分,使用计算机对学生档案信息进行管理具有手工管理所无法比拟的优点,如检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等,能够极大地提高学生档案管理的效率。所以我想借本次课程设计之际,设计一个简易的宿舍管理查询软件。

     1.2 功能需求分析

       为方便学生宿舍信息的管理,设计一个宿舍管理查询系统,系统能输入每个人的基础信息,存入文件中进行归档;打印出文件中已存在的所有学生信息;可以根据学生的各种关键字对学生信息进行查找;能根据学号查找到学生信息后对学生信息进行修改或删除操作;也能够通过不同的方式对学生信息进行排序。

具体要求:

  • 输入学生信息:输入学生的学号、姓名、性别、年龄、班级、宿舍号等各项基本信息,并能录入文件中存档。
  • 查询学生信息:采用顺序查找和二分查找两种方法对学生信息进行查找,能按学号、姓名等各项信息分别查找学生的完整记录信息。
  • 修改学生信息:能修改学生各项信息。
  • 删除学生信息:能删除任意个数的指定学生信息。
  • 打印学生信息:能够打印存储在数据库中的所有学生宿舍信息。
  • 排序学生信息:采用冒泡、选择和插入排序对学生信息进行排序。

     1.3 数据需求分析

       本次课程设计的题目是宿舍管理查询软件,要求可以存入学生信息,学生信息包括学生学号、姓名、班级、年龄、班级、宿舍号等各项基本信息,如下表1.1。该系统主要有以下六个功能,即对学生信息进行:输入、打印、查询、修改、删除、排序等功能。

宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

       数据结构的四种抽象类型分别是:集合结构、线性结构、树结构和网状结构,根据对该系统所需数据的分析,系统采用线性结构。顺序存储和链式存储是数据的两种最基本的存储结构,跟据用户的需求,学生宿舍管理系统的常见操作是查找、修改、筛选工作,而插入删除操作较少,所以,在本系统中采用存储密度大且能实现随机存取的顺序存储结构。

2. 系统设计

      2.1 数据结构类型设计

       为了对学生信息进行统一操作,使用了结构体这一数据结构,学生的各项数据信息都能用结构体来表示,具体设计如下:

typedef struct Student
{
	int  StuId;//学生学号
	char StuName[20];//学生姓名
	char StuGender[10];//学生性别
	int  StuAge;//学生年龄
	char StuClass[40];//学生所属班级
	int  StuRoom;//学生房间号
}Student;

        该结构体数据定义为全局变量。

      2.2 整体功能结构设计

宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

模块功能描述:

      1.系统登录模块:打开系统首先进入登录界面,正确输入系统口令后进入主菜单控制模块,如果五次口令输入错误则强制退出系统。

       2.主菜单控制模块:主菜单直接控制六个模块,在各模块间起到纽带的作用。在主菜单,可以通过选择进入其他模块,其他模块运行结束后也可回到主菜单继续选择。

       3.学生宿舍信息录入模块:初次打开系统,依次输入学生信息,建立学生宿舍信息数据库并保存文件,下次打开系统时,之前录入的信息依然存在并且可以选择继续输入或进行其他操作。

       4.学生宿舍信息打印模块:打印出存储在学生宿舍信息数据库的所有学生的各项信息。

       5.学生宿舍信息修改模块:根据学号查找到要修改的学生信息后,可对该学生的各项信息进行选择并修改,修改成功后可选择继续修改或返回主菜单。

       6.学生宿舍信息查询模块:可选择不同的方法(顺序查找或二分查找)进行查询。根据学生的学号、姓名、班级等其他信息进行查找,如果学生信息不存在则给出提示,查询成功会显示该学生全部信息,并可以选择继续查询或返回主菜单。

       7.学生宿舍信息排序模块:选择不同的条件对学生信息进行排序,可以选择学号、班级、宿舍号或姓名对所有在数据库中的学生信息进行排序。排序成功后可选择继续用其他方式排序或者返回主菜单。

       8.学生宿舍信息删除模块:通过学号查找到要删除的学生宿舍信息后,对其进行删除。成功删除后可选择继续删除其他学生信息或返回主菜单。

       2.3 子模块详细设计

        结构化的程序设计主要靠设计和调用各模块的函数来实现。本程序设计了多个函数,每个函数自身能完成一个任务,有的函数和别的函数结合能完成更大的任务。每一个模块功能的实现其实就是对函数的调用,本说明首先介绍本程序所涉及的子函数,再介绍主函数,最后介绍程序整体的实现过程。

      2.4 程序流程图设计

宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

        这里应该还有给个子模块的详细解释以及流程图,这是本人大二的数据结构课程设计,文档写的非常详细,由于赶时间就先不写了,如果后面有时间再回来补上,或者大家留言我来加上(大学生主打一个互帮互助!!!),因为本人是个小菜鸟代码有许多地方比较冗余和低级的地方让各位大佬见笑了。下面直接放代码。

3.系统实现

      3.1 系统源代码

#define _CRT_SECURE_NO_WARNINGS
#include"stdio.h"
#include"stdlib.h"
#include"string.h"
#include <conio.h> 
#include "windows.h"
#include<iostream>
using namespace std;
#include <iomanip>
using std::setw;
#define MAX 1000//最大学生人数
string HelloKey;

//学生结构体
typedef struct Student
{
	int  StuId;//学生学号
	char StuName[20];//学生姓名
	char StuGender[10];//学生性别
	int  StuAge;//学生年龄
	char StuClass[40];//学生所属班级
	int StuRoom;//学生房间号
}Student;

//查找指针
typedef struct Points
{
	int a;
	Points* points;
}Points;

char Revise[10] = "修改";
char Search[10] = "查询";
char Id[] = "学号";
char Name[] = "姓名";
char Gender[] = "性别";
char Age[] = "年龄";
char Class[] = "班级";
char Room[] = "宿舍";

//返回主菜单
void Pause() 
{
	int i;
	cout << "\n按回车键返回主菜单!" << endl;
	_getch();
}

//输出
void Print(Student stu[], int point)
{
	cout << "\n\n学号:" << stu[point].StuId << "姓名:" << stu[point].StuName << "性别:" << stu[point].StuGender
		<< "年龄:" << stu[point].StuAge << "班级:" << stu[point].StuClass << "宿舍号:" << stu[point].StuRoom << endl;
}

//查找失败
void PrintNotFound() 
{
	cout << "查找失败!找不到该数据" << endl;
}

//输出查找结果
void PrintSearch(Student stu[], int i) 
{
	cout << std::left <<"      " << setw(12) << stu[i].StuId << setw(13) << stu[i].StuName << setw(12) << stu[i].StuGender <<
		setw(10) << stu[i].StuAge << setw(15) << stu[i].StuClass << setw(10) << stu[i].StuRoom << endl;
}

//输出表头
void PrintHead()
{
	cout << "*******************************************************************************" << endl;
	cout << "      学号:      姓名:      性别:      年龄:      班级:      宿舍号:" << endl;
	cout << "*******************************************************************************" << endl;
}

//继续操作或返回主菜单
int a = 1;//默认继续
//继续操作请按1,返回主菜单请按0
void SelectOperate()
{
button:

	cout << "继续操作请按1,返回主菜单请按0" << endl;
	cin >> a;
	if (!(a == 1 || a == 0))
	{
		cout << "输入错误!请重新输入" << endl;
	//	_getch();
		goto button;
	}
}

//读取文件,返回总个数
int ReadFile(Student stu[])
{
	FILE* fp;
	int point = -1;
	if ((fp = fopen("Student.txt", "r")) == NULL)
	{
		cout << "\n学生宿舍文件不存在!请创建" << endl;
		return 0;
	}
	while (!feof(fp))
	{
		point++;
		fread(&stu[point], sizeof(Student), 1, fp);
	}
	fclose(fp);
	return point;
}

//存储数据到文件中 
void SaveFile(Student stu[], int sum)//sum是总个数 
{
	FILE* fp;
	int i;
	if ((fp = fopen("Temp.txt", "w")) == NULL)
	{
		printf("写文件错误!\n");
		return;
	}
	for (i = 0; i < sum; i++)
		if (fwrite(&stu[i], sizeof(Student), 1, fp) != 1)
			printf("写文件错误!\n");

	fclose(fp);
	remove("Student.txt");
	rename("Temp.txt", "Student.txt");

}

//创建学生信息,返回的是总数
int InPut(Student stu[], int sum)
{
	int x;
	for (; sum < MAX;sum++)
	{
		system("cls");//清屏
		cout << "\t\t\t" << "**********************************" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "*        创建学生宿舍信息        *" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "**********************************" << endl;
		cout << endl << endl;
		cout << "           请录入第" << sum + 1 << "学生信息  (最多" << MAX << "个)" << endl;
		cout << "请输入学生的学号:";
		cin >> stu[sum].StuId;
		cout << "请输入学生的姓名:";
		cin >> stu[sum].StuName;
		cout << "请输入学生的性别:";
		cin >> stu[sum].StuGender;
		cout << "请输入学生的年龄:";
		cin >> stu[sum].StuAge;
		cout << "请输入学生的班级:";
		cin >> stu[sum].StuClass;
		cout << "请输入学生的宿舍号:";
		cin >> stu[sum].StuRoom;
		cout << "创建成功!" << endl;
		
		//选择操作
		SelectOperate();
		if (a == 0)
		{
			return sum + 1;
		}
	}
	return sum + 1;
}

//打印学生信息
void OutPut(Student stu[], int sum)
{
	int i;
	system("cls");
	cout << "\t\t\t" << "**********************************" << endl;
	cout << "\t\t\t" << "*                                *" << endl;
	cout << "\t\t\t" << "*        打印学生宿舍信息        *" << endl;
	cout << "\t\t\t" << "*                                *" << endl;
	cout << "\t\t\t" << "**********************************" << endl;
	PrintHead();
	for (i = 0; i < sum; i++)
	{
		PrintSearch(stu, i);
	}
	Pause();

}

//排序
//复制Student,排好的装在一个新的students数组里 ,不要存到文件中
void CopyStu(Student stu0[], Student stu[], int sum)
{
	int i;
	for (i = 0; i < sum; i++)
	{
		stu[i].StuId = stu0[i].StuId;
		strcpy(stu[i].StuName, stu0[i].StuName);
		strcpy(stu[i].StuGender, stu0[i].StuGender);
		stu[i].StuAge = stu0[i].StuAge;
		strcpy(stu[i].StuClass, stu0[i].StuClass);
		stu[i].StuRoom = stu0[i].StuRoom;
	}
}

//交换数据元素
void ExchangeData(Student* stu1, Student* stu2)
{
	stu1->StuId = stu2->StuId;
	stu1->StuRoom = stu2->StuRoom;
	stu1->StuAge = stu2->StuAge;
	strcpy(stu1->StuName, stu2->StuName);
	strcpy(stu1->StuGender, stu2->StuGender);
	strcpy(stu1->StuClass, stu2->StuClass);
}

//排序菜单
int SelectSort()
{
	int ch;
	cout << "\t\t\t" << "**************************************" << endl;
	cout << "\t\t\t" << "*        请您选择条件进行排序        *" << endl;
	cout << "\t\t\t" << "*             1. 学号                *" << endl;
	cout << "\t\t\t" << "*             2. 班级                *" << endl;
	cout << "\t\t\t" << "*             3. 宿舍号              *" << endl;
	cout << "\t\t\t" << "*             4. 姓名                *" << endl;
	cout << "\t\t\t" << "*             0. 返回主菜单          *" << endl;
	cout << "\t\t\t" << "**************************************" << endl;
	cin >> ch;
	return ch;
}

//根据宿舍号从小到大排序(冒泡)
void Sort_Room(Student stu0[], int sum, Student stup[])
{
	Student stu1;//交换中间值
	int i, j;
	CopyStu(stu0, stup, sum);
	for (i = 0; i < sum - 1; i++)
	{
		for (j = 0; j < sum - 1 - i; j++)
		{
			if (stup[j].StuRoom > stup[j + 1].StuRoom)
			{
				ExchangeData(&stu1, &stup[j]);
				ExchangeData(&stup[j], &stup[j + 1]);
				ExchangeData(&stup[j + 1], &stu1);
			}
		}
	}
}

//根据班级从小到大排序(选择)
void Sort_Class(Student stu0[], int sum, Student stup[])
{
	Student stu1;
	int i, j, k = 0;
	CopyStu(stu0, stup, sum);
	for (i = 0; i < sum - 1; i++)
	{
		k = i;
		for (j = i + 1; j < sum; j++)
		{
			if (strcmp(stup[k].StuClass, stup[j].StuClass) > 0 )
			{
				k = j;
			}
		}
		if (i != k)
		{
			ExchangeData(&stu1, &stup[i]);
			ExchangeData(&stup[i], &stup[k]);
			ExchangeData(&stup[k], &stu1);
		}
	}
}

//根据姓名从大到小排序(折半插入排序)
//因为这里是从stu[1]开始操作的,所以得再创个中间变量
void Sort_Name(Student stu0[], int sum, Student stup[])
{
	Student stu1;//中间变量
	Student stu[1000];
	int i, j, low, high, mid;
	for (i = 0; i < sum; i++) {
		stu[i + 1].StuId = stu0[i].StuId;
		strcpy(stu[i + 1].StuName, stu0[i].StuName);
		strcpy(stu[i + 1].StuGender, stu0[i].StuGender);
		stu[i + 1].StuAge = stu0[i].StuAge;
		strcpy(stu[i + 1].StuClass, stu0[i].StuClass);
		stu[i + 1].StuRoom = stu0[i].StuRoom;
	}

	for (i = 2; i < sum + 1; i++) {
		ExchangeData(&stu1, &stu[i]);    //保存待插入元素到stu1
		low = 1; high = i - 1;
		while (low <= high)
		{
			mid = (low + high) / 2;
			if (strcmp(stu1.StuName, stu[mid].StuName) > 0)
				low = mid + 1;
			else
				high = mid - 1;
		}

		for (j = i - 1; j >= high + 1; j--)
			ExchangeData(&stu[j + 1], &stu[j]);//后移元素,留出插入空位 
			ExchangeData(&stu[high + 1], &stu1);
	}

	for (i = 0; i < sum; i++) {
		stup[i].StuId = stu[i + 1].StuId;
		strcpy(stup[i].StuName, stu[i + 1].StuName);
		strcpy(stup[i].StuGender, stu[i + 1].StuGender);
		stup[i].StuAge = stu[i + 1].StuAge;
		strcpy(stup[i].StuClass, stu[i + 1].StuClass);
		stup[i].StuRoom = stu[i + 1].StuRoom;
	}
	
}

//根据学号从小到大排序(插入希尔排序)
void ShellInsert(Student stup[], int sum, int dk)
{
	int i, j, k;
	Student stu1;//中间变量
	for (k = 0; k < dk; k++)
		for (i = dk + k; i < sum; i = i + dk)
			if (stup[i].StuId < stup[i - dk].StuId)
			{
				ExchangeData(&stu1, &stup[i]);
				for (j = i - dk; j >= 0 && stu1.StuId < stup[j].StuId; j = j - dk)//记录向后移    			
					ExchangeData(&stup[j + dk], &stup[j]);
					ExchangeData(&stup[j + dk], &stu1);
			}
}
void Sort_Id(Student stu[], int sum, Student stup[])
{
	int i, x;
	CopyStu(stu, stup, sum);
	int dlta[5] = { 5,4,3,2,1 };
	for (x = 0; x < 5; x++)
		ShellInsert(stup, sum, dlta[x]);
}

//排序主函数
void SortStudent(Student stu[], int sum)
{
	Student stup[1000];//把排好序的放在这里
	int ch, x, i;
	do {
		system("cls");//清屏
		cout << "\t\t\t" << "**********************************" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "*        学生宿舍信息排序        *" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "**********************************" << endl;
	select:
		ch = SelectSort();//排序菜单

		system("cls");
		cout << "\t\t\t" << "**********************************" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "*        学生宿舍信息排序        *" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "**********************************" << endl;

		switch (ch)
		{
		case 1:Sort_Id(stu, sum, stup); break;//按学号排序
		case 2:Sort_Class(stu, sum, stup); break;//按班级排序
		case 3:Sort_Room(stu, sum, stup); break;//按宿舍排序
		case 4:Sort_Name(stu, sum, stup); break;//按姓名排序
		case 0:return;
		default:cout << "输入错误!请重新输入" << endl; goto select;
		}
		//排序后打印输出
		PrintHead();
		for (i = 0; i < sum; i++)
		{
			PrintSearch(stup, i);
		}
		if (ch == 1 || ch == 2 || ch == 3 || ch == 4)
		{
			cout << endl << endl;
		button:
			cout << "继续排序请按1,返回主菜单请按0 " << endl;
			cin >> x;
			if (x == 1)
				x = 1;
			else if (x == 0)
				continue;
			else
			{
				cout << "输入错误!请重新输入" << endl;
				goto button;
			}
		}
		else if (ch == 0)
			x = 0;
		else
		{
			cout << "输入错误!请重新输入" << endl;
			goto select;
		}

	} while (x == 1);//x==1循环,x==0跳回主菜单
}

//查询或修改的选择菜单
int SelectChoice(char condition[20])
{
	int choice;
	cout << "\t\t\t" << "**************************************" << endl;
	cout << "\t\t\t" << "*        请您选择条件进行"<< condition << "        *" << endl;
	cout << "\t\t\t" << "*             1. 学号                *" << endl;
	cout << "\t\t\t" << "*             2. 姓名                *" << endl;
	cout << "\t\t\t" << "*             3. 性别                *" << endl;
	cout << "\t\t\t" << "*             4. 年龄                *" << endl;
	cout << "\t\t\t" << "*             5. 班级                *" << endl;
	cout << "\t\t\t" << "*             6. 宿舍号              *" << endl;
	cout << "\t\t\t" << "*             0. 返回主菜单          *" << endl;
	cout << "\t\t\t" << "**************************************" << endl;
	cin >> choice;
	return choice;
}

Points* ConnectPoint(Points* r, Points* p, int i) {
	p = new Points;
	p->a = i;
	r->points = p;
	r = p;
	return r;
}

//choice为条件选择,condition为条件(学号,姓名,性别,年龄,班级,宿舍号)
Points* FindPoint(Student stu[], int sum, int choice, char condition[])
{
	int i, j = 0; Points* p, * q, * r; q = new Points; p = new Points; r = q;
	int StuId, StuAge, StuRoom; char StuClass[20], StuGender[5], StuName[20];
	cout << "请输入您要查找的学生的" << condition;
	switch (choice)
	{
	case 1:
		cin >> StuId;
		for (i = 0; i < sum; i++)
		{
			if (StuId == stu[i].StuId)
			{
				r = ConnectPoint(r, p, i);
			}
		}
		break;
		
	case 2:
		cin >> StuName;
		for (i = 0; i < sum; i++)
		{
			if (strcmp(StuName, stu[i].StuName) == 0)
			{
				r = ConnectPoint(r, p, i); 
			}
		}
		break;
		
	case 3:
		cin >> StuGender;
		for (i = 0; i < sum; i++)
		{
			if (strcmp(StuGender, stu[i].StuGender) == 0)
			{
				r = ConnectPoint(r, p, i);
			}
		}
		break;
	case 4:
		cin >> StuAge;
		for (i = 0; i < sum; i++)
		{
			if (StuAge == stu[i].StuAge)
			{
				r = ConnectPoint(r, p, i);
			}
		}
		break;
	case 5:
		cin >> StuClass;
		for (i = 0; i < sum; i++)
		{
			if (strcmp(StuClass, stu[i].StuClass) == 0)
			{
				r = ConnectPoint(r, p, i);
			}
		}
		break;
	case 6:
		cin >> StuRoom;
		for (i = 0; i < sum; i++)
		{
			if (StuRoom == stu[i].StuRoom)
			{
				r = ConnectPoint(r, p, i);
			}
		}
		break;
	}
	r->points = NULL;
	return q;
}

//查询学生信息
void Inquire(Student stu[], int sum)
{
	int choice;
	Points* p;
	do {
		system("cls");//清屏
		cout << "\t\t\t" << "**********************************" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "*        查询学生宿舍信息        *" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "**********************************" << endl;
	button:
		choice = SelectChoice(Search);
		system("cls");//清屏
		cout << "\t\t\t" << "**********************************" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "*        查询学生宿舍信息        *" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "**********************************" << endl;
	switch (choice)
	{
	case 1: p = FindPoint(stu, sum, choice, Id); break;
	case 2: p = FindPoint(stu, sum, choice, Name); break;
	case 3: p = FindPoint(stu, sum, choice, Gender); break;
	case 4: p = FindPoint(stu, sum, choice, Age); break;
	case 5: p = FindPoint(stu, sum, choice, Class); break;
	case 6: p = FindPoint(stu, sum, choice, Room); break;
	case 0: return;
	default :
		cout << "输入错误!请输入正确的指令" << endl; goto button;//查询循环
	}
	if (p->points != NULL)
	{
		p = p->points;
		PrintHead();
		while (p != NULL)
		{
			PrintSearch(stu, p->a);
			p = p->points;
		}
	}
	else
		PrintNotFound();
		SelectOperate();//继续操作或返回主菜单
	} while (a);//默认a==1循环,选择a==0,则返回主菜单
}

//二分查找(目前有学号,姓名,宿舍)
Points* FindPoint2(Student stu[], int sum, int choice, char condition[])
{
	int i, j = 0; Points* p, * q, * r; q = new Points; p = new Points; r = q;
	int StuId, StuAge, StuRoom; char StuClass[20], StuGender[5], StuName[20];
	cout << "请输入您要查找的学生的" << condition;
	switch (choice)
	{
	case 1: cin >> StuId; break;
	case 2: cin >> StuName; break;
	case 3: cin >> StuRoom; break;
	}
	int flag = 0;
	int low = 0, high = sum - 1, mid;
	while (low <= high)
	{
		mid = (low + high) / 2;
		switch (choice)
		{
		case 1: if (StuId == stu[mid].StuId)
		      {
			  r = ConnectPoint(r, p, mid);
			  flag = 1;
		      }
			  else if (stu[mid].StuId > StuId)
		      {
			  high = mid - 1;
		      }
			  else
			  {
			  low = mid + 1;
		      }
		break;
		case 2: if (strcmp(StuName, stu[mid].StuName) == 0)
				{
				r = ConnectPoint(r, p, mid);
				flag = 1;
				}
				if (strcmp(stu[mid].StuName, StuName) > 0)
				 {
				  high = mid - 1;
				 }
				else
				{
				  low = mid + 1;
				}
		break;
		case 3: if (StuRoom == stu[mid].StuRoom)
		{
			   r = ConnectPoint(r, p, mid);
			   flag = 1;
		}
			   else if (stu[mid].StuRoom > StuRoom)
		{
			   high = mid - 1;
		}
			   else
		{
			   low = mid + 1;
		}
		break;
		}
		//找到,跳出循环
		if (flag)
		break;
	}
	r->points = NULL;
	return q;
}

//二分法查询学生信息
void Inquire2(Student stu[], int sum)
{
	Student stup1[1000];//引用,把排好序的放在这里,不跟原来的混淆 
	Student stup2[1000];//引用,把排好序的放在这里,不跟原来的混淆 
	Student stup3[1000];//引用,把排好序的放在这里,不跟原来的混淆 
	//先排序再二分
	Sort_Id(stu, sum, stup1);
	Sort_Name(stu, sum, stup2);
	Sort_Room(stu, sum, stup3);
	int choice;
	Points* p; p = new Points;
	do
	{
		system("cls");//清屏
		cout << "\t\t\t" << "**********************************" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "*        查询学生宿舍信息        *" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "**********************************" << endl;
	botton:
		cout << "\t\t\t" << "**************************************" << endl;
		cout << "\t\t\t" << "*        请您选择条件进行查询        *" << endl;
		cout << "\t\t\t" << "*             1. 学号                *" << endl;
		cout << "\t\t\t" << "*             2. 姓名                *" << endl;
		cout << "\t\t\t" << "*             3. 宿舍号              *" << endl;
		cout << "\t\t\t" << "*             0. 返回主菜单          *" << endl;
		cout << "\t\t\t" << "**************************************" << endl;
		cin >> choice;
		system("cls");//清屏
		cout << "\t\t\t" << "**********************************" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "*        查询学生宿舍信息        *" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "**********************************" << endl;
		switch (choice)
		{
		case 1:p = FindPoint2(stup1, sum, choice, Id); break;//二分法查询(学号) 
		case 2:p = FindPoint2(stup2, sum, choice, Name); break;//二分法查询(姓名)
		case 3:p = FindPoint2(stup3, sum, choice, Room); break;//二分法查询(房间号)
		case 0:return;
		default:cout << "输入错误!请重新输入" << endl; goto botton;//循环
		}
			if (p->points != NULL)
			{
				p = p->points;
				PrintHead();
				while (p != NULL)
				{
					if (choice == 1) {
						PrintSearch(stup1, p->a);
						p = p->points;
					}
					if (choice == 2) {
						PrintSearch(stup2, p->a);
						p = p->points;
					}
					if (choice == 3) {
						PrintSearch(stup3, p->a);
						p = p->points;
					}
				}
			}
			else
				PrintNotFound();
			//选择继续查询还是退回主菜单
			SelectOperate();	
	} while (a);
}

//选择查找方法
void SelectInquire(Student stu[], int sum)
{
	int ch;
	system("cls");
button:
	
	cout << "\t\t\t" << "**************************************" << endl;
	cout << "\t\t\t" << "*        请您选择方法进行查询        *" << endl;
	cout << "\t\t\t" << "*             1. 顺序查找            *" << endl;
	cout << "\t\t\t" << "*             2. 二分查找            *" << endl;
	cout << "\t\t\t" << "*             0. 返回主菜单          *" << endl;
	cout << "\t\t\t" << "**************************************" << endl;
	cin >> ch;
	switch (ch)
	{
	case 1: Inquire(stu, sum); break;//顺序查找
	case 2: Inquire2(stu, sum); break;//二分查找
	case 0: return;
	default:cout << "输入错误!请重新输入" << endl; goto button;//循环
	}
}

//修改和删除判断输入学生个数 
int OperateNum(int sum)
{
	int n;
	cout << "请输入您要操作的学生个数" << endl;
	cin >> n;
	if (n > sum)
	{
		cout << "操作失败!输入学生个数超过学生总量" << endl;
		SelectOperate();
		return 0;
	}
	else if (n <= 0)
	{
		cout << "操作失败!输入学生个数不能小于或对于零" << endl;
		SelectOperate();
		return 0;
	}
	return n;
}

//根据学号删除学生信息
int Delete(Student stu[], int sum)
{
	a = 1;
	system("cls");//清屏
	int i, j = 0, n = 0, flag = 1;
	Points* p;
	cout << "\t\t\t" << "**********************************" << endl;
	cout << "\t\t\t" << "*                                *" << endl;
	cout << "\t\t\t" << "*        删除学生宿舍信息        *" << endl;
	cout << "\t\t\t" << "*                                *" << endl;
	cout << "\t\t\t" << "**********************************" << endl;
	while (n == 0)
	{
		n = OperateNum(sum);//输入正确返回个数,输入不正确返回0(n=0),SelectOperate()里面选择a的取值(继续或返回主菜单)
		if (a == 0)
			return sum;
	}
	do {
		if (flag) {
			system("cls");
			Points* p;
			cout << "\t\t\t" << "**********************************" << endl;
			cout << "\t\t\t" << "*                                *" << endl;
			cout << "\t\t\t" << "*        删除学生宿舍信息        *" << endl;
			cout << "\t\t\t" << "*                                *" << endl;
			cout << "\t\t\t" << "**********************************" << endl;
		}
			//查一个删一个
			p = FindPoint(stu, sum, 1, Id);
			p = p->points;
			if (p != NULL)
			{
				i = p->a;
				//把后面的一次覆盖掉前面一个 
				for (; i < sum - 1; i++)
				{
					ExchangeData(&stu[i], &stu[i + 1]);
				}
				cout << "该条信息删除成功!" << endl;
				flag = 0;
				j++;
				if (j == n)
				{
					cout << "完成全部删除操作!" << endl;
					SelectOperate();//继续操作请按1,返回主菜单请按0
					if (a == 0)
						return sum - n;//剩余学生信息个数
					else
						Delete(stu, sum - n);
				}
			}
			else
			{
				cout << "输入的学号不存在!" << endl;
					SelectOperate();
					if (a == 0)
						return sum - j;
			}
	} while (a == 1 && j < n);
}

//根据学号修改学生信息
void Change(Student stu[], int sum)
{
	int choice;
	Points* p;
	do
	{
		system("cls");
		cout << "\t\t\t" << "**********************************" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "*        修改学生宿舍信息        *" << endl;
		cout << "\t\t\t" << "*                                *" << endl;
		cout << "\t\t\t" << "**********************************" << endl;
		p = FindPoint(stu, sum, 1, Id);//先查找再删除
		p = p->points;
		if (p != NULL)
		{
			system("cls");
			cout << "\t\t\t" << "**********************************" << endl;
			cout << "\t\t\t" << "*                                *" << endl;
			cout << "\t\t\t" << "*        修改学生宿舍信息        *" << endl;
			cout << "\t\t\t" << "*                                *" << endl;
			cout << "\t\t\t" << "**********************************" << endl;
			int i = p->a;
			Print(stu, i);
		button:
			choice = SelectChoice(Revise);
			switch (choice)
			{
			case 1: cout << "请输入您要修改的新学号:";
				cin >> stu[i].StuId;
				break;
			case 2: cout << "请输入您要修改的新姓名:";
				cin >> stu[i].StuName;
				break;
			case 3: cout << "请输入您要修改的新性别:";
				cin >> stu[i].StuGender;
				break;
			case 4: cout << "请输入您要修改的新年龄:";
				cin >> stu[i].StuAge;
				break;
			case 5: cout << "请输入您要修改的新班级:";
				cin >> stu[i].StuClass;
				break;
			case 6: cout << "请输入您要修改的新宿舍号:";
				cin >> stu[i].StuRoom;
				break;
			case 0:
				return;
			default:
				cout << "输入错误!请重新输入" << endl;
				goto button;
			}
			cout << "修改成功!" << endl;
			Print(stu, i);
		}
		else
			PrintNotFound();
		SelectOperate();
		if (a == 0)
		{
			return;
		}
	} while (a);
}

void SystemMain();
//欢迎界面密码输入错误
int HelloKey_Result()
{
	int n = 5;//最大输入次数
	for (int i = 1; i <= n; i++)
	{
		if (HelloKey == "admin123")//默认系统密码
		{
			return 1;
		}
		else
		{
			if (i < n)
			{
				cout << "密码错误!请重新输入。"
					<< "您已经输入了" << i << "次," << "剩余" << n - i << "次机会" << endl;
				cin >> HelloKey;

			}
			if (i == n)
			{
				cout << "密码错误!您已经输入" << i << "次,自动退出宿舍管理系统。" << endl;
				exit(0);
			}

		}
	}
	
}

//退出界面
void Bye()
{
	cout << "成功退出!感谢您的使用" << endl;
	cout << "欢迎您下次使用宿舍管理系统!" << endl;
}

//欢迎界面
void Hello() 
{
	cout << "\t\t\t" << "**********************************" << endl;
	cout << "\t\t\t" << "*        宿舍管理查询软件        *" << endl;
	cout << "\t\t\t" << "*          设计者:               *" << endl;
	cout << "\t\t\t" << "*        指导老师:               *" << endl;
	cout << "\t\t\t" << "*           专业:                *" << endl;
	cout << "\t\t\t" << "*        2023年XX月XX日          *" << endl;
	cout << "\t\t\t" << "**********************************" << endl;
	cout << endl;
	cout << "请输入系统口令:(admin123)" << endl;
	cin >> HelloKey;
		HelloKey_Result();
}

//宿舍管理系统主页面
void SystemMain()
{
	Student stu[20];
	int choice, sum;
	sum = ReadFile(stu);
	if (sum == 0)
	{
//		cout << "进入信息录入系统,按回车键继续" << endl;
//		_getch();
		cout << "3秒后自动进入信息录入系统..." << endl;
		Sleep(3000);
		sum = InPut(stu, sum);
	}
	system("cls");
	do
	{
		system("cls");//清屏
		button:
		cout << "欢迎您进入宿舍管理系统" << endl;
		cout << "\t\t\t" << "********************************************" << endl;
		cout << "\t\t\t" << "*          请从主菜单中选择您的操作        *" << endl;
		cout << "\t\t\t" << "*              1.录入学生宿舍信息          *" << endl;
		cout << "\t\t\t" << "*              2.打印学生宿舍信息          *" << endl;
		cout << "\t\t\t" << "*              3.查询学生宿舍信息          *" << endl;
		cout << "\t\t\t" << "*              4.修改学生宿舍信息          *" << endl;
		cout << "\t\t\t" << "*              5.删除学生宿舍信息          *" << endl;
		cout << "\t\t\t" << "*              6.排序学生宿舍信息          *" << endl;
		cout << "\t\t\t" << "*              0.退出宿舍管理系统          *" << endl;
		cout << "\t\t\t" << "********************************************" << endl;
		cin >> choice;
		switch (choice)
		{
		case 1: sum = InPut(stu, sum); break;//录入学生信息
		case 2: OutPut(stu, sum); break;//打印学生信息
		case 3: SelectInquire(stu, sum); break;//查询学生信息
		case 4: Change(stu, sum); break;//修改学生信息
		case 5: sum = Delete(stu, sum); break;//删除学生信息
		case 6: SortStudent(stu, sum);//排序学生信息
		case 0: Bye(); break;
		default:cout << "输入错误!请重新输入" << endl;
			goto button;
		}
		SaveFile(stu, sum);
	} while (choice != 0);
}

int main()
{
    cout << "恭喜你发现了这篇博客,觉得不错就点个赞吧!" << endl;
    Hello();
    SystemMain();
	
}

4.运行效果截图(部分)

宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构 宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

 宿舍管理查询软件数据结构课程设计,课程设计,c语言,c++,数据结构

5.写在最后 

       由于我是第一次发,也比较好奇有多少人看hhhh辛苦各位大佬投投票我瞧瞧,另外大学生帮助大学生啦,马上期末了应该有不少同学也要被这个课程设计折磨了,居然借鉴了就留个小赞吧(感谢)(其实我这个代码也借鉴了但是我找不到原创了,然后也修修改改各种缝合,也可以凑合看看吧)(缝合怪罢了)(大学生对付作业罢了)文章来源地址https://www.toymoban.com/news/detail-755280.html

到了这里,关于数据结构课程设计-宿舍管理查询软件-(C/C++)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构课程设计C/C++版--植物百科数据的管理与分析

    注意:评测不通过请重置代码仓库,重新评测 第1关:增加植物信息 任务描述 本关任务:已知plant.txt的路径为\\\"data_edit/plant.txt\\\",从plant.txt中读取植物的基本信息,创建一个植物信息的链表,基于该链表,实现植物基本信息的增加功能。 编程要求 根据提示,在右侧编辑器补充

    2024年04月11日
    浏览(184)
  • 《数据结构》课程设计(C/C++版):植物百科数据的管理与分析

    目录 第1关:增加植物信息 第2关:删除植物信息 第3关:修改植物信息 第4关:基于顺序表的顺序查找 第5关:基于链表的顺序查找 第6关:基于顺序表的折半查找 第7关:基于二叉排序树的查找 第8关:基于开放地址法的散列查找 第9关:基于链地址法的散列查找 第10关:基于

    2024年04月09日
    浏览(200)
  • 基于C语言的数据结构课程设计(学生管理系统、停车场管理、家谱管理、校园导航系统)

    一、设计目的 本课程设计是软件工程学生的必修课程,数据结构与算法课程设计既是一门基础课程,又是一门实践性课程。 通过本实训课程的学习和训练,使同学学会分析研究数据对象的特性,学会数据的组织方法,以便选择合适的数据逻辑结构和存储结构,以及相应的运

    2024年02月09日
    浏览(58)
  • C语言版数据结构-课程设计-航空客运订票系统 V2.0 附源码(增加管理员功能)

    相信很多粉丝看过看过我的主页,有一个航空订票系统: 数据结构航空订票系统(附源码) 但是最近后台收到很多粉丝的要求,在上一个航空订票系统中要加上管理员的功能块,于是对上面那个课设进行了改进,新的功能流程如下: (航班信息由管理员添加和删除、顾客可

    2024年02月03日
    浏览(53)
  • 【数据库课设】图书馆资源管理系统 源码+流程图+结构设计(借还图书 逾期罚款 图书管理 读者管理 信息查询)python实现

    一个管理员编号对应一个密码,且需要有管理员注册密匙。 可以在图书信息表中录入、修改、删除图书。 可以在图书信息表中查询书籍。 可以编辑图书借阅、归还信息。 可以编辑欠款信息。 可以编辑读者信息表。 图书馆注册,获得读者编号。 可以在图书信息表中查阅书籍

    2024年02月10日
    浏览(50)
  • 数据结构课程设计

    编制一个能演示执行集合的交、并和差运算的程序。 要求: 集合元素用小写英文字母,执行各种操作应以对话方式执行。 算法要点:利用单链表表示集合;理解好三种运算的含义 分析 : 输入:输入应该具有判断是否为小写字母的功能,如果不是小写字母,应该舍去,同时

    2024年02月02日
    浏览(47)
  • 课程项目设计--项目建立--宿舍管理系统--springboot后端

    前要 项目设计–宿舍管理系统 太长了,修改一下 暂时先加上下面依赖,还有的话以后在看 application.yml application-dev.yml 新加一个handler包,用于像mybatis自动填充的处理配置 具体配置mybaits-plus配置 注解 插件bean 这里先只配置分页插件 自动填充bean 这里有2种写法,注释掉的是低

    2024年02月12日
    浏览(40)
  • 【数据结构课程设计】关键路径问题

    1 问题描述与功能需求分析 1.1问题描述 1) 任务:设计一个程序求出完成整项工程至少需要多少时间以及整项工程中的关键活动。 2)基本要求: (1)对一个描述工程的 AOE 网,应判断其是否能够顺利进行。 (2)若该工程能顺利进行,输出完成整项工程至少需要多少时间,以及

    2024年02月10日
    浏览(45)
  • 数据结构课程设计1: 区块链

    1.任务: [问题描述] 使用链表设计一个保存信息的系统,该系统拥有类似区块链的设计以防止信息被轻易篡改。 该题目使用一个链表。信息保存在链表的每一个节点中,每个节点需要包含该节点的编号、信息和校验码。其中: + 每个节点的编号按照顺序递增,从0开始。 + 节

    2023年04月16日
    浏览(114)
  • 数据结构课程设计 ——考试报名系统

    数据结构课程设计 ——考试报名系统 一、项目功能要求 完成对考生信息的建立,查找,插入,修改,删除等功能。其中考生信息包括准考证号,姓名,性别,年龄和报考类别等信息。项目在设计时应首先确定系统的数据结构,定义类的成员变量和成员函数;然后实现各成员

    2024年02月04日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包