我对 C++ 不是很有经验,所以如果我犯了一些(很多)愚蠢的错误,我提前道歉。
该任务的指令如下: 在类 AVector 中,声明一个 double 类型的动态数组来存储欧几里得向量的元组,并声明一个整数成员来存储向量的维数。我们应该让用户输入 v1 和 v2 的大小和值。然后我们应该使用 v1 和 v2 来生成以下格式的输出。
v3 = v1 + v2 = (v1[0]+v2[0] v1[1]+v2[1] .... v1[n]+v2[n])
v3 = v1 - v2 = (v1[0]-v2[0] v1[1]-v2[1] .... v1[n]-v2[n])
v3 = v1 * v2 = (v1[0]*v2[0] + v1[1]*v2[1] + .... + v1[n]*v2[n])
如果 v1 和 v2 中的元素数量不同或其中一个为空,我们应该会产生错误消息。
例子:
如果 v1 的动态数组有 3 个元素:1.0 2.5 3.0
如果 v2 的动态数组有 3 个元素: 2.0 2.0 1.0
然后输出是:
v3 = v1 + v2 = (3.0 4.5 4.0)
v3 = v1 - v2 = (-1.0 0.5 2.0)
v3 = v1 * v2 = 10
现在,我的问题是我不断收到“错误:函数“processVector”必须有一个原型。” 即使 processVector 的函数原型确实存在。
到目前为止,我所拥有的如下:
#include<iostream>
class AVector
{
private:
int size;
double* array;
public:
AVector()
{
array = NULL;
}
AVector(int)
{
double input;
size = a;
array = new double[size];
int counter = 0;
while(counter < size)
{
cin >> input;
array[counter] = input;
counter++;
}
}
~AVector()
{
delete[] array;
}
void printArray(int a)
{
cout << "Euclidean vector v" << a << " = (";
for(int i = 0; i < size; i++)
{
cout << array[i] << ' ';
}
cout << ')' << endl;
}
void processVector(AVector a, AVector b)
{
if(a.size != b.size)
{
cout << "Two Euclidean vector should be in the same Euclidean space" << endl;
}
else
{
//...
}
}
};
主文件
#include<iostream>
#include "AVector2.h"
using namespace std;
int main()
{
int dimension;
cout << "Input dimension and tuples for a Euclidean vector v1: ";
cin >> dimension;
AVector v1 = AVector(dimension);
v1.printArray(1);
cout << endl;
cout << "Input dimension and tuples for a Euclidean vector v2: ";
cin >> dimension;
AVector v2 = AVector(dimension);
v2.printArray(2);
cout << endl;
processVector(v1, v2);
return 0;
}
如果有人能指出我做错了什么,我将不胜感激。先感谢您。