我对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
{
//...
}
}
};
的main.cpp
#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;
}
如果有人能够指出我做错了什么,我会非常感激。 提前谢谢。
答案 0 :(得分:3)
processVector
是AVector
的非静态成员函数。这意味着必须在像AVector
这样的v1.processVector(v2, v3);
对象上调用它。也许您希望它成为static
成员函数,因此您可以这样调用它:
AVector::processVector(v1, v2);