matrices.h

来自「这是linux下的进化计算的源代码。 === === === === ==」· C头文件 代码 · 共 43 行

H
43
字号
#ifndef MATRICES_H#define MATRICES_H#include <vector>class lower_triangular_matrix {    unsigned n;    std::vector<double> data;    public:    lower_triangular_matrix(unsigned n_ = 0) : n(n_), data(n * (n+1) / 2) {};        void resize(unsigned n_) {	n = n_;	data.resize(n*(n+1)/2);    }        std::vector<double>::iterator operator[](unsigned i) { return data.begin() + i * (i+1) / 2; }    std::vector<double>::const_iterator operator[](unsigned i) const { return data.begin() + i*(i+1)/2; }};class square_matrix {    unsigned n;    std::vector<double> data;    public:    square_matrix(unsigned n_ = 0) : n(n_), data(n * n) {};        void resize(unsigned n_) {	n = n_;	data.resize(n*n);    }        std::vector<double>::iterator operator[](unsigned i) { return data.begin() + i * n; }    std::vector<double>::const_iterator operator[](unsigned i) const { return data.begin() + i*n; }};#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?