向量不是可递增的错误

时间:2015-03-23 13:23:42

标签: c++ visual-c++

我正在用C ++编写一个实现Newton-Raphson方法的程序,除此之外,还定义了一个多项式类:

#include <iostream>
#include <algorithm>
#include <utility>
#include <string>
#include <cmath>
#include <vector>
#include <set>

using namespace std;

class polynomial{

    using pair_dd = pair<double, double>;

public:
    polynomial(const vector<pair_dd>& v) : m_coeff(simplify(v)) {} // constructor
    polynomial(const polynomial& p) : m_coeff(p.m_coeff){} // copy constructor
    polynomial derivative() const{ // computes derivative
        vector<pair_dd> dcoeff;
        for_each(begin(m_coeff), end(m_coeff), [&](pair_dd p){
            dcoeff.emplace_back(pair_dd(p.first*p.second, p.second - 1));
        });
        return polynomial(dcoeff);
    }
    double apply(double x) const{ // applies poly to argument
        auto sum(0.0);
        for_each(begin(m_coeff), end(m_coeff), [&](pair_dd p){
            sum += p.first*pow(x, p.second);
        });
        return sum;
    }
    void write() const{ // prints polynomial
        // function just for testing
        for (const auto& term : m_coeff)
            cout << term.first << "x^" << term.second << " +";
        cout << endl;
    }

private:
    polynomial(); //forbid empty constructor
    vector<pair_dd> m_coeff;
    vector<pair_dd> simplify(const vector<pair_dd>& v) const{

        set<double> exp; // set of exponents
        for (const auto& term : v)
            exp.insert(term.second);

        vector<pair_dd> ret; // final simplified vector
        vector<pair_dd> temp; // temporary object

        for (const auto& power : exp){
            copy_if(begin(v), end(v), begin(temp), [&](const pair_dd p){
                return (p.second == power);
            });
            // combine terms
            auto sum(0.0);
            for (auto& p : temp)
                sum += p.first;
            ret.push_back(pair_dd(sum, power));
            temp.clear();
        }
        return ret;
    }
};


int main(){

    vector<pair<double, double>> vec;
    vec.push_back(pair<double, double>(5,1)); // 5x
    vec.push_back(pair<double, double>(10, 1)); // 10x
    vec.push_back(pair<double, double>(3, 2)); // 3x^2

    polynomial poly(vec);

    // should write 15x + 3x^2

    poly.write();
    return 0;
}

我遇到的问题是simplify函数在copy_if位置运行时导致错误。据说

  

矢量temp不可递增

在Visual Studio中

。我的算法的工作方式是通过在一个集合中收集具有相同x的幂的所有项(因为我们只需要唯一的元素)。随后,我遍历指数集,使用对向量上的copy_if将所有具有相同指数的项组合在一起,然后将它们组合并放入最终向量中。

我已经尝试了保留和调整临时矢量的大小。

2 个答案:

答案 0 :(得分:6)

copy_if不会分配内存,它假定temp已经调整大小,而不是<iterator>。您可以使用copy_if(begin(v), end(v), back_inserter(temp), [&](const pair_dd p){ return (p.second == power); }); 中的std::back_inserter

{{1}}

答案 1 :(得分:3)

您正在尝试复制到空白向量中,您需要先调整大小,或使用可根据需要调整大小的插入器:

copy_if(begin(v), end(v), back_inserter(temp), [&](const pair_dd p){
            return (p.second == power);
        });