期中考模拟题

T1:判断矩形是否重叠(复合类+友元)

 T2:计算平均绩点(友元函数)

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


class  lesson{
	public:
	lesson(){};
	void set(string _num,double _credit,string _grade){
		num=_num;
		credit=_credit;
		grade=_grade;
	}
	friend double get(lesson *p,int n);
	friend double gpa(lesson *p,int n,double sumgrade);
	void print(lesson &p,int n){
		
			cout<<fixed(2)<<setprecision<<p.num<<' ';
					
		
		
	} 
	~lesson(){};
	private:
		string num;
		double credit;
		string grade;
		
		
		
	
};
	double get(lesson *p,int n){
		double sum=0;
		for(int i=0;i<n;i++){
			sum+=p[i].credit;
		}
		return sum;//forget
		
	}
	double gpa(lesson *p,int n,double sumgrade){
		double sum=0,k;
		for(int i=0;i<n;i++){
		if(p[i].grade=="A+") k=4.5*p[i].credit;
		if(p[i].grade=="A") k=4*p[i].credit;
		if(p[i].grade=="B+")k=3.5*p[i].credit;
		if(p[i].grade=="B") k=3*p[i].credit;
		if(p[i].grade=="C+") k=2.5*p[i].credit;
		if(p[i].grade=="C") k=2*p[i].credit;
		if(p[i].grade=="D") k=1*p[i].credit;
		if(p[i].grade=="F") k=0*p[i].credit;
		sum=sum+k;
		}
		double gpa=sum/sumgrade;
		return gpa;
	}
int main()

{
	int test,n;
	cin>>test;
	string num,grade;
	double  credit;
	while(test--){
		cin>>n;
		lesson *p=new lesson [n];
		for(int i=0;i<n;i++){
			cin>>num>>credit>>grade;
			p[i].set(num,credit,grade);
		}
		for(int i=0;i<n;i++){
			p[i].print(p[i],n);
		}
		cout<<endl;//one 友元two类成员函数void 
		double sumgrade=get(p,n);
		cout<<sumgrade<<' ';
		cout<<gpa(p,n,sumgrade)<<endl;
	}
	return 0;
}

Tips:封面为转载,侵权删

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值