1

我知道这通常不是最好的主意,但我决定试一试。我正在尝试重载 + 运算符以对两个向量进行元素明智的添加。由于某种原因,它仅正确返回向量中的第一个值。我不知道出了什么问题?如果我在计算 sum 数组的元素时使用 push_back 而不是调整大小,它也将不起作用。这是代码:

    #include "stdafx.h"
    #include <iostream>
    #include "conio.h"
    #include <vector>

    using namespace std;

    class dvector{

    public:
        vector<double> q;
        dvector(vector<double>);
        dvector();
    };
    dvector::dvector(vector<double> a) {
        q=a;
    };
    dvector::dvector() {
        vector<double> q;
    };

    dvector operator+(dvector c1, dvector c2)
    {
        int sz=c1.q.size();
        dvector sum;
        sum.q.resize(sz);
        double temp;
        for (int i=0; i<sz; i++){
            sum.q[i]=c1.q[i]+c2.q[i];
            return sum;
        }
    }


    int _tmain(int argc, _TCHAR* argv[])

    {
        vector<double> test1;
        test1.resize(10);
        for (int i=0; i<10;i++){
            test1[i]=i;
        }
        vector<double> test2;
        test2.resize(10);
        for (int i=0; i<10;i++){
            test2[i]=2;
        }
        dvector dtest1(test1); 
        dvector dtest2(test2); 
        dvector sum=dtest1+dtest2;

        for (int i =0;i<10;i++)

            {
                cout<<sum.q[i]<<' ';
            }
        getch();
        return 0;
    }
4

2 回答 2

5

returnfor第一次迭代后立即进入您的循环。你应该移到return sum;最后一行operator+

于 2013-10-22T08:53:25.787 回答
4

因为你回来太快了。return 语句不仅会跳出,for loop还会退出函数。

dvector operator+(dvector c1, dvector c2)
{
    int sz=c1.q.size();
    dvector sum;
    sum.q.resize(sz);
    double temp;
    for (int i=0; i<sz; i++){
        sum.q[i]=c1.q[i]+c2.q[i];
        //return sum;  // don't return until you finish calculating
    }
    return sum;    // move to here
}
于 2013-10-22T08:53:47.960 回答