2021-06-17

C++语言实现学生信息管理系统

  1. 实验介绍
    本实验使用C++语言实现功能:录入学生成绩信息。实现对录入的详细学生数据增加、删除、查询、统计、排序、相关功能的操作。对内存数据通过保存到文件,实现数据的持久化,重新启动程序时,文件数据会加载到内存。
    通过实验,可以学习对linux c++语言的类的封装,方法的实现、调用,以及文件的读写有初步的了解。
  2. 代码开发
    本实验采用华为提供的代码,实际上课过程中可作为编程题目,让学生自行完后才能代码编写。程序文件:sms_f.cpp,代码如下:
    sms_f.cpp:
    /**学生信息包括:学号、姓名、平时成绩、期末考试成绩。
    主菜单:
    =================================================
    = 欢迎使用成绩管理系统 =
    = 1=录入学生 2=显示信息 =
    = 3=排序总评 4=查找学生 =
    = 5=插入学生 6=删除学生 =
    = 7=统计人数 0=退出 =

================================================*/

#include<iostream>
#include<fstream>
#include<iomanip>
#include<string> 
using namespace std;

const int MAX_STUDENT_NUM=5;
class Student
{
	public:
		void inputId();//输入学号 
		void inputName();// 输入姓名 
		void inputRegularGrade();//输入平时成绩 
		void inputFinaExam();//输入期末考试成绩 
		int getId();// 获得学号
		static void heading()//输出成绩标题
		{
			cout<<setw(10)<<"学号"<<setw(10)<<"姓名"<<setw(10)<<"平时"<<setw(10)<<"期末"<<endl;
		}
		void output();//输出成绩信息 
		float CalTatalMark();//计算总评成绩=平时*50%+期末*50%
	private: 
		int id;//学号
		char name[20]; //姓名
		float regularGrade;//平时成绩
		float finalExam;//期末考试成绩 
};

void Student::inputId()
{
	cout<<"请输入学号(1-40之间):";
	cin>>id;
	while(id<1||id>40)
    {
      cout<<"输入学号有误,请重新输入学号(1-40之间): "<<endl;
      cin>>id;    
    }
    
}

void Student::inputName()
{
	cin.ignore(80,'\n');
	cout<<"请输入姓名:";
	cin.getline(name,20);
}

void Student::inputRegularGrade()
{
	cout<<"请输入平时成绩(0-100之间):";
	cin>>regularGrade;
	while(regularGrade<0||regularGrade>100)
    {
        cout<<"输入错误,成绩应该在0到100之间!"<<endl;
        cout<<"请输入平时成绩(0-100之间):";
        cin>>regularGrade;    
    }
}

void Student::inputFinaExam()
{
	cout<<"请输入期末考试成绩(0-100之间):";
	cin>>finalExam;
	while(finalExam<0||finalExam>100)
  {
    	cout<<"输入错误,成绩应该在0到100之间!"<<endl;
    	cout<<"请输入期末考试成绩(0-100之间):";
      cin>>finalExam;    
  }
}

int Student::getId()
{
	return id;
}

void Student::output()
{
	cout<<setw(10)<<id<<setw(10)<<name<<setiosflags(ios::fixed)<< setprecision(1)<<setw(10)<<regularGrade<<setw(10)<<finalExam<<endl;
}
 
float Student::CalTatalMark()
{
	return regularGrade*0.5+finalExam*0.5;
}
 
//录入或插入学生信息 
void Input(Student stu[], int &num)
{
//	float score;//学生成绩
	int i=0; //人数
	string str;//用来判断是否继续输入的字符串
	if(num==0)
	{
		while(true)
		{
			stu[i].inputId();
			for(int j=0;j<num;j++)
			{
				if(stu[i].getId()==stu[j].getId())
				{
					cout<<"学号不允许重复,该学号已经存在!\n"; 
					stu[i].inputId();
				}
			} 
			stu[i].inputName();
			stu[i].inputRegularGrade();
			stu[i].inputFinaExam();
			i++;
			num=i;
			cout<<"继续输入学生数据请按y或Y:";
			cin>>str;
			if(i==MAX_STUDENT_NUM)
			{
				cout<<"人数已达到"<<MAX_STUDENT_NUM<<"人上限,无法再输入!\n";
				break;
			}
			if(str=="y" || str=="Y")
			{
				continue;
			}
			else
			{
				break;
			}
		}
	}
	else //插入学生信息 
	{
		if(num==MAX_STUDENT_NUM)
		{
			cout<<"人数已达到"<<MAX_STUDENT_NUM<<"人上限,无法再插入!\n";
		}
		else
		{
			i=num;//当前数组元素个数
			while(true)
			{
				stu[i].inputId();
				for(int j=0;j<num;j++)
				{
					if(stu[i].getId()==stu[j].getId())
					{
						cout<<"学号不允许重复,该学号已经存在!\n"; 
						stu[i].inputId();
					}
				} 
				stu[i].inputName();
				stu[i].inputRegularGrade();
				stu[i].inputFinaExam();
				i++;
				num=i;
				cout<<"继续输入学生数据请按y或Y:";
				cin>>str;
				if(i==MAX_STUDENT_NUM)
				{
					cout<<"人数已达到"<<MAX_STUDENT_NUM<<"人上限,无法再输入!\n";
					break;
				}
				if(str=="y" || str=="Y")
				{
					continue;
				}
				else
				{
					break;
				}
			}
		}
	}
}

//输出显示成绩信息 
void Output(Student stu[], int num)
{
	if(num!=0)
	{
		stu[0].heading();//学生信息标题
		for(int i=0;i<num;i++)
		{
			stu[i].output();
		}
	}
	else
	{
		cout<<"暂无成绩信息,请选择1=录入学生信息"<<endl;
	}		
}

//根据总评排序 
void Order(Student stu[], int num)
{
	if(num!=0)
	{
		int i,j,k;
		Student temp;  
		for(i=0;i<num;i++)
		{
			for(j=0;j<num-i-1;j++)
			{
				if(stu[j].CalTatalMark()<stu[j+1].CalTatalMark())
				{
					temp = stu[j];
					stu[j] = stu[j+1];
					stu[j+1] = temp;
				}
			}
		}
		stu[0].heading();//学生信息标题
		for(k=0;k<num;k++)
		{
			stu[k].output();
		}
		cout<<endl;
	}
	else
	{
		cout<<"暂无成绩信息,请选择1=录入学生信息"<<endl;
	}
}  

//查找学生信息 
void Search(Student stu[], int num)
{
	int id;
	string str;//用来判断是否继续输入的字符串
	while(true)
	{
		cout<<"请输入您要查找的学号:";
		cin>>id;
		int flag=0;
		if(id>=1 && id<=40)
		{
			for(int i=0;i<num;i++)
			{
				if(stu[i].getId()==id)
				{
					flag++;
				}
			}
			if(flag==0)
			{
				cout<<"没有该学号学生信息!"<<endl;
			}
			else
			{
				stu[0].heading();//学生信息标题
				for(int i=0;i<num;i++)
				{
					if(stu[i].getId()==id)
					{
						stu[i].output();
					}
				}
			}
			cout<<"继续查找请按y或Y:";
			cin>>str;
			if(str=="y" || str=="Y")
			{
				continue;
			}
			else
			{
				break;
			}
		}
		else
		{
			cout<<"输入学号有误,请重新输入学号(1-40之间)\n "<<endl;
			cout<<"继续查找请按y或Y:";
			cin>>str;
			if(str=="y" || str=="Y")
			{
				continue;
			}
			else
			{
				break;
			}
		}
	}
}
 
void Delete(Student stu[], int &num)
{
	int id;
	string str;//用来判断是否继续输入的字符串
	while(true)
	{
		cout<<"请输入要删除学生的学号:";
		cin>>id;
		int flag=0;//用来统计删除后剩余的数组元素个数
		Student a[100];
		if(id>=1 && id<=40)
		{
			for(int i=0;i<num;i++)
			{
				if(stu[i].getId()!=id)
				{
					a[flag]=stu[i];
					flag++;
				}
			}
			if(flag==num)
			{
				cout<<"没有该学号学生!"<<endl;
			}
			else
			{
				num=flag;
				for(int k=0;k<num;k++)
				{
					stu[k]=a[k];
				}
				cout<<id<<"号学生信息删除成功!"<<endl;
			}
			cout<<"继续删除其他学生请按y或Y:";
			cin>>str;
			if(str=="y" || str=="Y")
			{
				continue;
			}
			else
			{
				break;
			}
		}
		else
		{
			cout<<"输入学号有误,请重新输入学号(1-40之间)!\n";
			cout<<"继续删除其他学生请按y或Y:";
			cin>>str;
			if(str=="y" || str=="Y")
			{
				continue;
			}
			else
			{
				break;
			}
		}
	}
}
 
//统计人数 
void Statis(Student stu[], int num)
{
	int	i,a[5]={0};
	for(i=0;i<num;i++)
	{
		if(stu[i].CalTatalMark()>=90 && stu[i].CalTatalMark()<=100)
		{
			a[0] +=1;
		}
		else if(stu[i].CalTatalMark()>=80 && stu[i].CalTatalMark()<90)
		{
			a[1] +=1;
		}
		else if(stu[i].CalTatalMark()>=70 && stu[i].CalTatalMark()<80)
		{
			a[2] +=1;
		}
		else if(stu[i].CalTatalMark()>=60 && stu[i].CalTatalMark()<70)
		{
			a[3] +=1;
		}
		else
		{
			a[4] +=1;
		}
	}
	cout<<"     100~90    89~80    79~70    69~60     <60"<<endl;
	for(i=0;i<5;i++)
	{
		cout<<setw(9)<<a[i];
	}
	cout<<endl;
}
 
//主菜单 
void Menu()
{
	cout<<"          =================================================\n";
	cout<<"          =              欢迎使用成绩管理系统             =\n";
	cout<<"          =           1=录入学生     2=显示信息           =\n";
	cout<<"          =           3=排序总评     4=查找学生           =\n";
	cout<<"          =           5=插入学生     6=删除学生           =\n";
	cout<<"          =           7=统计人数     0=退出               =\n";
	cout<<"          =================================================\n";
	cout<<"请选择:";
}
 
int main()
{
	int currentN=0;
	Student stu[MAX_STUDENT_NUM];
	/*从文件读数据 */ 
	ifstream Filein("students.dat",ios::binary);
	if(Filein)
	{
		Filein.read((char*)&currentN,sizeof(currentN));
		for(int i=0;i<currentN;i++)
		{
			Filein.read((char*)&stu[i],sizeof(stu[i]));
		}
	}
	Filein.close();
	string a;//用来判断菜单选择,用string 
	Menu();
	while(cin>>a)
	{
			
		if(a=="1")
		{
			cout<<"您选择了1=录入学生"<<endl;
			Input(stu, currentN);//输入
			Menu();
		}
		else if(a=="2")
		{
			cout<<"您选择了2=显示信息"<<endl; 
			Output(stu, currentN);//输出成绩信息
			Menu();
		}
		else if(a=="3")
		{
			cout<<"您选择了3=排序总评"<<endl;
			Order(stu, currentN);
			Menu();
		}
		else if(a=="4")
		{
			cout<<"您选择了4=查找学生"<<endl;
			Search(stu, currentN);
			Menu();
		}
		else if(a=="5")
		{	
			cout<<"您选择了5=插入学生"<<endl;
			Input(stu, currentN);
			Menu();
		}
		else if(a=="6")
		{
			cout<<"您选择了6=删除学生"<<endl;
			Delete(stu, currentN);
			Menu();
		}
		else if(a=="7")
		{
			cout<<"您选择了7=统计人数"<<endl;
			Statis(stu, currentN);
			Menu();
		}
		else if(a=="0")
		{ 
			/*往文件写入数据*/
			ofstream fileout("students.dat",ios::binary);
			if(!fileout)
			{
				cout<<"文件不能被打开!"<<endl;
				return 0;
			}
			fileout.write((char*)&currentN,sizeof(currentN));
			for(int i=0;i<currentN;i++)
			{
				fileout.write((char*)&stu[i],sizeof(stu[i]));
			}
			fileout.close();
			cout<<"退出成功!"<<endl;
			return 0;
		} 
		else
		{
			cout<<"输入非法,请重新输入!"<<endl;
			Menu();
		}
		
	}
	return 0;
}
<think>好的,我现在需要处理用户关于复合材料频散曲线计算方法及软件仿真的问题。首先,我得理解用户的需求。他们可能是在研究复合材料的波动特性,比如声学或弹性波传播,想要知道如何计算频散曲线,以及用什么软件进行仿真。频散曲线显示的是波速随频率变化的情况,对复合材料设计和分析很重要。 接下来,我需要确定用户问题中的关键点:复合材料、频散曲线、计算方法、分析、软件仿真。可能用户需要了解不同的计算方法,比如解析法、数值法(如有限元、边界元),以及各种仿真软件如COMSOL、ANSYS、ABAQUS的应用。 然后,我得考虑如何组织信息。根据用户的要求,回答需要分步骤或方法,每个部分换行,避免使用第一人称和步骤词汇。还要确保引用内容不集中在末尾,而是分散在相关部分。此外,需要检查是否需要数学公式或代码,用户提到如果有的话,必须用正确的格式。比如,频散方程可能有公式,如$c_p = \omega / k$,其中c_p是相速度,ω是角频率,k是波数。 关于软件仿真部分,需要列出常用的软件,并简要说明它们的应用方法和特点。比如COMSOL的波动模块,ANSYS的模态分析,或者专用工具如Disperse。同时,可能需要提到计算步骤,如建模、材料定义、边界条件设置、求解和后处理。 然后,生成相关问题。需要确保问题基于原始内容和回答,可能包括如何选择合适的方法,实验验证的方法,或不同软件之间的比较。 现在,需要验证是否有遗漏的信息,比如是否覆盖了主要的计算方法和软件,是否解释了频散曲线在复合材料中的应用,以及是否有实际的操作步骤或注意事项。同时,确保没有使用被禁止的格式,如第一人称或步骤词汇,引用分散,代码和公式正确标记。 最后,检查相关问题的部分是否符合要求,至少三个,用正确格式,基于用户的问题和回答内容。比如,可能的问题涉及方法比较、实验验证、软件教程、各向异性的影响等。</think>针对复合材料频散曲线的计算分析,主要通过理论建模和软件仿真两种方式实现。以下为具体方法及工具分类说明: **理论计算方法** 1. **传递矩阵法** 建立复合材料的层间传递矩阵模型,通过求解特征方程$det(\mathbf{T} - e^{ikd}\mathbf{I}) = 0$获得频散关系。适用于层状结构分析,需处理复数特征值问题。 2. **谱有限元法** 将波动方程离散为频域形式,构建刚度矩阵$\mathbf{K}(\omega) - \omega^2\mathbf{M}$,求解特征频率对应的波数$k$。适合复杂几何结构,计算量随频率增加而增大。 3. **各向异性Christoffel方程** 对于纤维增强复合材料,通过弹性常数矩阵$\mathbf{C}_{ijkl}$构建Christoffel方程: $$(C_{ijkl}n_jn_l - \rho c^2 \delta_{ik})p_k = 0$$ 求解相速度$c$频率关系,需处理复杂的本构关系。 **软件仿真工具** ```python # COMSOL波动模块示例代码 model = Model() model.component("comp1").physics("solidmech").feature("f1").set("Frequency", "1000[Hz]") model.study("std1").feature("freq").set("plist", "range(1000,1000,10000)") ``` 1. **COMSOL Multiphysics** - 使用波动模块建立层状模型 - 设置各向异性材料参数 - 进行频率扫描求解特征频率 2. **ANSYS Mechanical** - 通过Modal分析获取固有频率 - 使用Harmonic Analysis计算频响函数 - 结合APDL脚本实现参数化扫描 3. **Disperse专业软件** - 内置多层复合材料模型库 - 自动生成Lamb波频散曲线 - 支持横观各向同性材料分析 **关键参数设置注意事项** - 材料坐标系需纤维方向对齐 - 阻尼系数采用Rayleigh阻尼模型$C = \alpha M + \beta K$ - 网格尺寸应满足$\lambda_{min}/8$精度要求 - 边界条件建议设置无限元或完美匹配层(PML)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值