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 + -
显示快捷键?