小明经营着一个不大的水果店(似曾相识哦~),只销售苹果、香蕉和桔子。为了促销,小明制定了如下定价策略:
苹果:按斤论价,每斤P元,买W斤,则需支付WP元。
香蕉:半价,每斤P元,买W斤,则需支付W/2P元。
桔子:按斤论价,每斤P元,买W斤。如果W>10,则打半价,即需支付W * P/2元;否则如果W>5,则打八折,即需支付W * P * 0.8元;其他情况不打折,即需支付W*P元。
请用C++来计算某个顾客采购的水果的总价。该程序至少应有:
Fruit类:是个抽象类,是Apple、Banana和Orange的父类。支持重载的加法运算。
Apple、Banana和Orange类:分别对应于苹果、香蕉和桔子三种水果,每种水果执行不同的定价策略。
输入
输入为多行,每行格式为:
C W P
其中C是水果类型(a、b、o分别代表苹果、香蕉和桔子),W和P分别是顾客购买的相应水果的重量和每斤水果的单价。输入完成后输入字符q结束输入。
输出
输出顾客需支付的总金额。
样例输入
a 1 1
b 1 1
o 1 1
q
样例输出
2.5
#include<iostream>
using namespace std;
class Fruit
{
virtual double sum() = 0;
friend double operator+(Fruit& x, double ans);
};
class Apple:public Fruit
{
double w, p;
public:
Apple(double x, double y)
{
w = x;
p = y;
}
virtual double sum()
{
return w * p;
}
};
class Banana:public Fruit
{
double w, p;
public:
Banana(double x, double y)
{
w = x;
p = y;
}
virtual double sum()
{
return w/2 * p;
}
};
class Orange:public Fruit
{
double w, p;
public:
Orange(double x, double y)
{
w = x;
p = y;
}
virtual double sum()
{
if(w>10)
return w * p/2;
if (w > 5)
return w * p * 0.8;
else
return w * p;
}
};
double operator+(Fruit& x, double ans)
{
ans += x.sum();
return ans;
}
int main()
{
Fruit* fru[100];
char a;
int total = 1;
cin >> a;
double w, p, ans = 0;
while (a != 'q')
{
cin >> w >> p;
if (a == 'a')
{
fru[total] = new Apple(w, p);
total++;
}
if (a == 'b')
{
fru[total]=new Banana(w, p);
total++;
}
if (a == 'o')
{
fru[total] = new Orange(w, p);
total++;
}
}
for (int i = 0; i < total; i++)
{
ans = *fru[i] + ans;
}
cout << ans;
return 0;
}
望采纳
题主原来的类设计逻辑没改,只是将main函数改了下,就可以达到效果。
说一下需要修改的地方:
1、 Fruit* fru[100];这里的类数组,下标是从0开始的,题主原来的逻辑int total = 1; 运行到后面重载相加代码会崩溃,所有这里total值初始化为0;
2、由于题目需要的是每轮都要cin输入a、b、o,显然把cin >> a,放在while循环外面,不能达到效果,这里更改为do while循环,先执行再判断循环。
具体修改如下:
int main()
{
Fruit* fru[100];
char a = {};
int total = 0;
double w, p, ans = 0;
do
{
cin >> a;
if (a != 'q')
{
cin >> w >> p;
}
else
{
break;
}
if (a == 'a')
{
fru[total] = new Apple(w, p);
total++;
}
else if (a == 'b')
{
fru[total] = new Banana(w, p);
total++;
}
else if (a == 'o')
{
fru[total] = new Orange(w, p);
total++;
}
} while (a != 'q');
for (int i = 0; i < total; i++)
{
ans = *fru[i] + ans;
}
cout << ans;
return 0;
}