机器人变身(类与对象)

题目描述

编写一个机器人类,包含属性有机器名、血量、伤害值、防御值、类型和等级。其中血量、伤害和防御和等级、类型相关:
普通型机器人,类型为N,血量、伤害、防御是等级的5倍
攻击型机器人,类型为A,攻击是等级的10倍,其他属性和普通的一样
防御型机器人,类型为D,防御是等级的10倍,其他属性和普通的一样
生命型机器人,类型为H,生命是等级的50倍,其他属性和普通的一样。

机器人操作包括:打印、各个属性的获取和设置方法,构造函数可有可无,根据需要自行编写

编写一个全局函数用于机器人变身,使得各种类型机器人能够相互转变。参数包括机器人对象指针和变身后的机器人类型,功能是修改机器人类型,并更改相关的属性。如果变身类型和机器人原来的类型不同,则执行变身功能,并返回true;如果变身类型和原来类型相同,则不执行变身,并返回false.

要求所有数据成员都是私有属性,用C++语言和面向对象设计思想来编程实现上述要求

输入

第一行输入t,表示要执行t次机器人变身

接着每两行,一行输入一个机器人的属性,包括机器名、类型、等级,机器名最大长度为20,另一行输入变身类型

依次类推输入

输出

每行输出变身后的机器人信息,要求调用机器人的打印方法来输出,即使机器人不变身也输出

属性输出依次为:名称、类型、等级、血量、伤害、防御

最后一行输出执行变身的次数

输入样例1

3
X001 N 5
H
X002 A 5
D
X003 D 5
D

输出样例1

X001--H--5--250--25--25
X002--D--5--25--25--50
X003--D--5--25--25--50
The number of robot transform is 2

 

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

class robot
{
	string name;
	char type;
	int blood, rank, hurt, defense;
public:
	robot(string n, char t, int r)
	{
		name = n;
		type = t;
		rank = r;
		switch (type)
		{
		case 'N':
			blood = 5 * rank;
			hurt = 5 * rank;
			defense = 5 * rank;
			break;
		case 'A':
			blood = 5 * rank;
			hurt = 10 * rank;
			defense = 5 * rank;
			break;
		case 'D':
			blood = 5 * rank;
			hurt = 5 * rank;
			defense = 10 * rank;
			break;
		case 'H':
			blood = 50 * rank;
			hurt = 5 * rank;
			defense = 5 * rank;
			break;
		}
	}
	friend bool turn(robot* ro, char turntype);
	void print()
	{
		cout << name << "--" << type << "--" << rank << "--" << blood << "--" << hurt << "--" << defense << endl;
	}
};

//全局函数bool
bool turn(robot* ro, char turntype)
{
	if (ro->type == turntype)
	{
		return false;
	}
	else
	{
		ro->type = turntype;
		switch (turntype)
		{
		case 'N':
			ro->blood = 5 * ro->rank;
			ro->hurt = 5 * ro->rank;
			ro->defense = 5 * ro->rank;
			break;
		case 'A':
			ro->blood = 5 * ro->rank;
			ro->hurt = 10 * ro->rank;
			ro->defense = 5 * ro->rank;
			break;
		case 'D':
			ro->blood = 5 * ro->rank;
			ro->hurt = 5 * ro->rank;
			ro->defense = 10 * ro->rank;
			break;
		case 'H':
			ro->blood = 50 * ro->rank;
			ro->hurt = 5 * ro->rank;
			ro->defense = 5 * ro->rank;
			break;
		}
		return true;
	}
}

int main()
{
	int t, sum = 0;
	cin >> t;
	while (t--)
	{
		string name;
		char type, turntype;
		int rank;
		cin >> name >> type >> rank >> turntype;
		robot r(name, type, rank);
		robot* p;
		p = &r; //important!!引用
		sum += turn(p, turntype);//若成立sum++,若不成立sum = sum
		p->print();
	}
	cout << "The number of robot transform is " << sum << endl;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值