地铁是当今城市较为流行的一种铁路运输的形式,地铁能避免城市地面拥挤,充分利用空间,具有运量大、准时、正点率较其他公交高、速度快等优点。请设计一个简易的地铁自动售票机系统。
功能需求:
(1)设计一个地铁路线类Router,包含路线编号,途中的各个站点。
(2)设计一个地图类Map,可以显示所有可以乘坐的地铁站名,以及线路信息。
(3)根据用户输入的起点和终点和人次信息,可以自动计算应付金额;根据用户输入的金额,计算找零信息;
#include
#include
#include
using namespace std;
class Router //定义地铁路线类 Router
{
private:
string name; //站名
int mun; //路线编号
public:
void play(); //用户输入信息
};
class Map //地图 Map
{
private:
string name; //站名
int num; //路线编号
public:
void display();
};
void Map::display() //显示地图信息
{
cout << "路线1:" << endl;
for (int n = 1; n < 11; n++)
cout << setw(4) << n;
cout << endl;
cout << "路线2:" << endl;
for (int i = 10; i > 0; i--)
cout << setw(4) << i;
cout << endl;
}
void Router::play()
{
int n, i, j, a, b;
do
{ //判断是否有此站
cout << "请输入起点:" << endl;
cin >> n;
if (n < 1 || n>10)
cout << "输入错误,请重新输入" << endl;
} while (n < 1 || n>10);
do
{ //判断是否有此站
cout << "请输入终点:" << endl;
cin >> i;
if (i < 1 || i>10)
cout << "输入错误,请重新输入" << endl;
else if (i == n)
cout << "输入错误,请重新输入" << endl;
} while (i < 1 || i>10 || i == n);
do
{ //乘车的人数
cout << "请输入有几人乘车:" << endl;
cin >> j;
if (j < 0)
cout << "输入错误,请重新输入" << endl;
} while (j < 0);
if (n > i) //线路1
{ //前3站3元一人,中间3站4元一人,最后3站5元一人
if (n - i <= 3)
{
a = 3 * j;
cout << "需要的金额为:" << a << endl;
cout << "支付的金额为:";
cin >> b;
cout << "应找补:" << b - a << endl;
}
else if (n - i >= 4 && n - i <= 6)
{
a = 4 * j;
cout << "需要的金额为:" << a << endl;
cout << "支付的金额为:";
cin >> b;
cout << "应找补:" << b - a << endl;
}
else if (n - i >= 7 && n - i <= 9)
{
a = 5 * j;
cout << "需要的金额为:" << a << endl;
cout << "支付的金额为:";
cin >> b;
cout << "应找补:" << b - a << endl;
}
}
else //线路2
{
if (i - n <= 3)
{
a = 3 * j;
cout << "需要的金额为:" << a << endl;
cout << "支付的金额为:";
cin >> b;
cout << "应找补:" << b - a << endl;
}
else if (i - n >= 4 && n - i <= 6)
{
a = 4 * j;
cout << "需要的金额为:" << a << endl;
cout << "支付的金额为:";
cin >> b;
cout << "应找补:" << b - a << endl;
}
else if (i - n >= 7 && n - i <= 9)
{
a = 5 * j;
cout << "需要的金额为:" << a << endl;
cout << "支付的金额为:";
cin >> b;
cout << "应找补:" << b - a << endl;
}
}
}
void main()
{
Map a;
a.display();
Router s;
s.play();
}