加湿风扇(虚继承)

题目描述

已知家电有编号、功率的属性,属性都是整数,操作包括构造和打印等

电风扇继承家电的特点,新增两个属性(整数):风向和风力, 其中风向为0表示定向吹风,状态为1表示旋转吹风。

电风扇包含两个新操作:风向控制和风力控制
1、风向控制含一个整数参数,无返回,把风向设置为参数值,参数为0表示定向吹风,为1表示旋转吹风。
2、风力控制含一个整数参数,无返回,把风力设置为参数值,参数表示风力级别,例如1级、2级、3级等。

加湿器继承家电的特点,新增两个属性(浮点数):实际水容量和最大水容量
新增操作是预警,无参数,返回值为整数,当实际水容量不小于最大水容量的50%,则返回1; 小于50%且不小于10%则返回2,小于10%则返回3

加湿风扇继承了风扇和加湿器的特点,新增属性档位(整数)
新增操作调整档位,含一个参数,无返回值,先设置档位为参数值,再调用风向控制和风力控制来设置相关属性,包括:
1、参数为0,不做其他属性修改
2、参数为1,设置定向吹风且风力1级
3、参数为2,设置旋转吹风且风力2级
4、参数为3,设置旋转吹风且风力3级

档位只可能是0、1、2、3四个数值,其他数值忽略。 加湿风扇重载打印操作,输出格式参考样本。输出要求如下:
1、如果风向为0,则输出定向吹风,风向为1则输出旋转吹风。
2、调用预警操作,并根据返回结果1、2、3输出不同信息,分别是:水量正常、水量偏低、水量不足

程序要求 1、采用虚拟继承机制实现上述电器的关系,明确谁是虚基类、基类、派生类 2、基类和派生类的构造要考虑虚基类、基类的属性构造

上述所有类属性都不是public,用面向对象思想和C++语言实现上述要求

输入

第一行输入t,表示有t个实例
第二行输入一个加湿风扇的信息,依次包括编号、功率、风向、风力、实际水容量、最大水容量 档位
第三行输入一个参数,表示调档操作的档位,然后执行调档操作。
以此类推,输入t个实例 输出 对于每个实例,调用打印操作输出加湿风扇的最终状态

样例输入

3 1001 1000 1 2 3 4 0 1 2002 2000 0 1 1 12 0 3 3003 3000 0 3 2 10
0 0

样例输出

加湿风扇–档位1
编号1001–功率1000W
定向吹风–风力1级
实际水容量3升–水量正常
加湿风扇–档位3
编号2002–功率2000W
旋转吹风–风力3级
实际水容量1升–水量不足
加湿风扇–档位0
编号3003–功率3000W
定向吹风–风力3级
实际水容量2升–水量偏低

#include <bits/stdc++.h>
using namespace std;

class Household_Appliance
{
protected:
	int num, power;

public:
	Household_Appliance() {}
	Household_Appliance(int n, int p)
	{
		num = n;
		power = p;
	}
	void show()
	{
		cout << "编号" << num << "--"
			 << "功率" << power << "W" << endl;
	}
};

class Fan : virtual public Household_Appliance
{
protected:
	int wind_direction, wind_power;

public:
	Fan() {}
	Fan(int n, int p, int w_d, int w_p) : Household_Appliance(n, p)
	{
		wind_direction = w_d;
		wind_power = w_p;
	}
	void control_d(int c)
	{
		wind_direction = c;
	}
	void control_p(int p)
	{
		wind_power = p;
	}
};

class Humidifier : virtual public Household_Appliance
{
protected:
	double actual_water, max_water;

public:
	Humidifier() {}
	Humidifier(int n, int p, double a_w, double m_w) : Household_Appliance(n, p)
	{
		actual_water = a_w;
		max_water = m_w;
	}
	int waring()
	{
		if (actual_water >= max_water * 0.5)
		{
			return 1;
		}
		if (actual_water < max_water * 0.5 && actual_water >= max_water * 0.1)
		{
			return 2;
		}
		if (actual_water < max_water * 0.1)
		{
			return 3;
		}
	}
};

class Wet_fan : public Humidifier, public Fan
{
protected:
	int gear;

public:
	Wet_fan(int n, int p, int w_d, int w_p, double a_w, double m_w, int g)
	{
		num = n;
		power = p;
		wind_direction = w_d;
		wind_power = w_p;
		actual_water = a_w;
		max_water = m_w;
		gear = g;
	}
	void control_gear(int g)
	{
		gear = g;
		switch (gear)
		{
		case 0:
			break;
		case 1:
		{
			control_d(0);
			control_p(1);
			break;
		}
		case 2:
		{
			control_d(1);
			control_p(2);
			break;
		}
		case 3:
		{
			control_d(1);
			control_p(3);
			break;
		}
		}
	}
	void show()
	{
		cout << "加湿风扇--"
			 << "挡位" << gear << endl
			 << "编号" << num << "--"
			 << "功率" << power << "W" << endl;
		switch (wind_direction)
		{
		case 0:
			cout << "定向吹风--";
			break;
		case 1:
			cout << "旋转吹风--";
			break;
		}
		cout << "风力" << wind_power << "级" << endl
			 << "实际水容量" << actual_water << "升--";
		switch (waring())
		{
		case 1:
			cout << "水量正常" << endl;
			break;
		case 2:
			cout << "水量偏低" << endl;
			break;
		case 3:
			cout << "水量不足" << endl;
			break;
		}
	}
};

int main()
{
	int t, n, p, w_d, w_p, g, gear;
	double a_w, m_w;
	cin >> t;
	while (t--)
	{
		cin >> n >> p >> w_d >> w_p >> a_w >> m_w >> g;
		Wet_fan A(n, p, w_d, w_p, a_w, m_w, g);
		cin >> gear;
		A.control_gear(gear);
		A.show();
	}
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值