编码方式修改

This commit is contained in:
2025-08-26 10:17:18 +08:00
parent 3cd5dca89e
commit 2d11592fd3

View File

@@ -39,7 +39,7 @@ LinSolver::LinSolver() :
sv::LinSolver::~LinSolver()
{
for (auto& var : vars) {
delete[] var.second; // <20>ͷ<EFBFBD>ԭ<EFBFBD><D4AD><EFBFBD>ڴ<EFBFBD>
delete[] var.second;
}
}
@@ -54,12 +54,12 @@ LinSolver& sv::LinSolver::operator=(const LinSolver& solver)
return *this;
}
for (auto& var : vars) {
delete[] var.second; // <20>ͷ<EFBFBD>ԭ<EFBFBD><D4AD><EFBFBD>ڴ<EFBFBD>
delete[] var.second;
}
vars.clear();
vars.reserve(solver.vars.size());
for (auto& var : solver.vars) {
vars.push_back(std::pair(var.first, new Var[var.first]));
vars.push_back(std::make_pair(var.first, new Var[var.first]));
for (int i = 0; i < var.first; i++) {
vars.back().second[i] = var.second[i];
}
@@ -81,14 +81,14 @@ Var* LinSolver::addVars(int num, VarType type)
for (int c = 0; c < num; c++) {
var[c].col = c + cn, var[c].type = type;
}
vars.push_back(std::pair(num, var));
vars.push_back(std::make_pair(num, var));
cn += num;
return vars.back().second;
}
Var& sv::LinSolver::getVar(int idx)
{
assert(idx >= 0 && idx < cn); // <20><><EFBFBD><EFBFBD>Խ<EFBFBD><D4BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
assert(idx >= 0 && idx < cn);
static Var err_var;
for (auto& var : vars) {
if (var.first <= idx) {
@@ -382,7 +382,7 @@ rtn LinSolver::feasible_solution()
rtn LinSolver::_pivot(pair<size_t, size_t>& p)
{
p = make_pair(0, 0);
double cmin = INT_MAX;
double cmin = DBL_MAX;
vector<double> coef = ope_table.front();
// === <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ԫ<EFBFBD><D4AA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Сֵ ===
@@ -395,7 +395,7 @@ rtn LinSolver::_pivot(pair<size_t, size_t>& p)
if (cmin >= 0) {
return OPTIMAL;
}
double bmin = INT_MAX;
double bmin = DBL_MAX;
for (size_t row = 1; row < bn; row++) {
double tmp = ope_table.at(row).front() / ope_table.at(row).at(p.second);
if (ope_table.at(row).at(p.second) > 0 && bmin > tmp) {
@@ -404,7 +404,7 @@ rtn LinSolver::_pivot(pair<size_t, size_t>& p)
}
}
if (abs(bmin - INT_MAX) < 1e-10) {
if (abs(bmin - DBL_MAX) < 1e-10) {
return UNBOUNDED;
}