Requisitos:
1. Usar funciones sobrecargadas para calcular el área de círculos, rectángulos, trapezoides y triángulos. Si no se especifican parámetros para el cálculo del área del círculo, se calcula el área del círculo unitario;
2. Obtener la entrada del programa , ruta de archivo y ruta de archivo de un archivo de texto El nombre es: D: \ Test.txt
3. El formato de entrada es el siguiente:
carácter único [] parámetro 1 [] parámetro 2 [] ... <retorno de carro y salto de línea >
Descripción:
(1) Separe por espacios y finalice un grupo de entradas con retorno de carro y avance de línea, y luego lea la siguiente línea de entrada hasta el final del archivo;
(2) Un solo carácter representa el tipo de forma: C (círculo) Parámetros: radio
R (rectangular) Parámetros: largo, ancho
L (trapezoide) Parámetros: arriba abajo, abajo abajo,
T alto (triangular) parámetros: abajo, alto
(3) Si el número de parámetros de entrada es mayor que el número requerido de parámetros, la entrada redundante será ignorada; si el número de parámetros de entrada es menor que el número requerido de parámetros, se llamará al valor de entrada anterior (si hay entrada antes) O 0 (si no hay entrada antes) );
(4) El cálculo del área del círculo, dados los parámetros predeterminados, genera el área del círculo unitario;
4. El resultado de la salida se muestra en la consola, el formato es el siguiente:
área en forma de XX = XXXXXX
5. Código ordenado y estándar
6. Diagrama de resultado de la operación adjunto, y explicar y analizar el caso de prueba, el propósito de la prueba y el resultado de la operación.
Código de implementación de C ++:
#include <fstream>
#include <sstream>
#include <iostream>
#include <vector>
#include <string>
#include <stdlib.h>
using namespace std;
double Area(double r = 1);//计算圆形的面积
double Area(double length, double width);//计算矩形的面积
double Area(double uSide, double lSide, double height);//计算梯形的面积
double Area(double lSide, double height, int i);//计算三角形的面积,为与计算矩形的
//面积区分开来,增加一个输入参数int i;
int main()
{
char ch[256];
int i;
float result; //最终结果
float backup[20][10]; //用于备份记录每一轮输入的数据
float Num[10]; //存放每一轮float类型数据
int k = 0; //记录轮数
string tempName;
ifstream ifile;
ifile.open("D:\\我学你妹\\大三上\\面向对象程序设计\\实验\\Test.txt");
do
{
ifile.getline(ch, 255); //按行读取字符串
//将得到的字符串按空格切割放入数组
char* p;
vector<string> num; //字符串数组
const char* delim = " ";
p = strtok(ch, delim);
while (p)
{
i = 0;
string s = p;
num.push_back(s);
p = strtok(NULL, delim);
i++;
}
//将数组中的字符转换为float类型
for (int i = 0; i < num.size(); ++i)
{
Num[i] = atof(num[i].c_str());
//std::cout << "b=" << Num[i] << std::endl;
backup[k][i] = Num[i]; //备份
}
k++;
if (ch[0] == 'C')
{
tempName = "圆形";
if (Num[1] != NULL)
{
result = Area(Num[1]);
}
else
{
result = Area();//利用默认参数求单位圆面积
}
}
else if (ch[0] == 'R')
{
tempName = "矩形";
if (Num[2] != NULL)
{
result = Area(Num[1], Num[2]);
}
else
{
result = Area(Num[1], backup[k-2][1]);
}
}
else if (ch[0] == 'L')
{
tempName = "梯形";
if (Num[3] != NULL) //从后往前判断是否有数据输入,如果没有则从备份数据中提取
{
result = Area(Num[1], Num[2], Num[3]);
}
else if (Num[2] != NULL )
{
result = Area(Num[1], Num[2], backup[k - 2][1]);
}
else if (Num[1] != NULL)
{
if (backup[k - 2][2] != NULL)
{
result = Area(Num[1], backup[k - 2][1], backup[k - 2][2]);
}
else
{
result = Area(Num[1], backup[k - 2][1], backup[k - 3][1]);
}
}
}
else if (ch[0] == 'T')
{
tempName = "三角形";
if (Num[2] != NULL)
{
result = Area(Num[1], Num[2],1);
}
else
{
result = Area(Num[1], backup[k - 2][1],1);
}
}
cout << tempName << "面积 = " << result << endl;
} while (ifile.eof() == 0);
ifile.close();
return 0;
}
double Area(double r)
{
return (3.14) * r * r;
}
double Area(double length, double width) {
return length * width;
}
double Area(double uSide, double lSide, double height) {
return (uSide + lSide)*height / 2;
}
double Area(double lSide, double height, int i) {
return lSide * height / 2;
}
Datos de entrada:
resultado de ejecución del programa: