c++实现单纯形法现行规划问题的求解
在本程序中默认该现行规划问题有最优解
针对此问题:
#include<iostream>
using namespace std; int check(float *sigema, int m) {
for (int i = ; i <= m ; i++) {
if (sigema[i] > ) {
return ;
}
}
return ;
} //此程序已经化为标准型的线性规划问题中,且默认有最优解
int main(int argc, char* argv[])
{
//数据输入部分
int m, n;
cout << "请输入变量个数:";
cin >> m;
cout << "请输入不等式个数:";
cin >> n;
float **matrix = new float*[n + ]; //系数矩阵
for (int i = ; i <= n; i++) {
matrix[i] = new float[m + ];
}
float *cj = new float[m + ];
float *cB = new float[n + ]; //基变量系数
int *XB = new int[n + ]; //用来标注基变量x的下标
float *b = new float[n + ];
float *sigema = new float[n + ];
float *sita = new float[n + ];
//初始化
for (int i = ; i <= m; i++) {
cj[i] = ;
}
for (int i = ; i <= n; i++) {
cB[i] = ;
XB[i] = ;
b[i] = ;
sigema[i] = ;
sita[i] = ;
}
cout << "请输入目标函数系数(用空格间开):" << endl;
for (int i = ; i <= m; i++) {
cin >> cj[i];
}
cout << "请输入各不等式的系数和常量(用空格间开):" << endl;
for (int i = ; i <= n; i++) {
cout << "不等式" << i << ": ";
for (int j = ; j <= m + ; j++) {
cin >> matrix[i][j];
}
}
cout << "请输入目标函数中基变量下标:" << endl;
for (int i = ; i <= n; i++) {
cin >> XB[i];
cB[i] = cj[XB[i]];
//常量
b[i] = matrix[i][m + ];
} //计算检验数
for (int i = ; i <= m; i++) {
sigema[i] = cj[i];
for (int j = ; j <= n; j++) {
sigema[i] -= cB[j] * matrix[j][i];
}
} while (check(sigema, m) == ) {
//寻找入基变量
float maxn = sigema[];
int sigema_xindex = ;
float sigema_xcoefficient = ;
for (int i = ; i <= m; i++) {
if (maxn <= sigema[i]) {
maxn = sigema[i];
sigema_xindex = i;
sigema_xcoefficient = cj[i];
}
}
//计算sita
for (int i = ; i <= n; i++) {
if (matrix[i][sigema_xindex] > ) {
sita[i] = b[i] / matrix[i][sigema_xindex];
}
else {
sita[i] = ; //表示sita值为负数
}
}
//寻找出基变量
float minn = sita[];
int sita_xindex = ;
for (int i = ; i <= n; i++) {
if (minn >= sita[i] && sita[i] > ) {
minn = sita[i];
sita_xindex = i;
}
}
//入基出基变换,先入基再出基
//入基操作
for (int i = ; i <= n; i++) {
if (i == sita_xindex) {
XB[i] = sigema_xindex;
cB[i] = sigema_xcoefficient;
break;
}
}
//出基计算
//化1
//cout << endl << "此处为化1的结果------" << endl;
float mul1 = matrix[sita_xindex][sigema_xindex];
for (int i = ; i <= m; i++) {
matrix[sita_xindex][i] /= mul1;
}
b[sita_xindex] /= mul1;
//化0
//cout << endl << "此处为化0的结果------" << endl;
for (int i = ; i <= n; i++) {
if (i == sita_xindex) {
continue;
}
float mul2 = matrix[i][sigema_xindex] / matrix[sita_xindex][sigema_xindex];
for (int j = ; j <= m; j++) {
matrix[i][j] -= (matrix[sita_xindex][j] * mul2);
}
b[i] -= (b[sita_xindex] * mul2);
}
for (int i = ; i <= n; i++) {
if (i == sita_xindex) {
continue;
}
}
for (int i = ; i <= m; i++) {
sigema[i] = cj[i];
for (int j = ; j <= n; j++) {
sigema[i] -= cB[j] * matrix[j][i];
}
}
}
float MaxZ = ;
float *result = new float[m + ];
for (int i = ; i <= m; i++) {
result[i] = ;
}
for (int i = ; i <= n; i++) {
result[XB[i]] = b[i];
}
cout << "最优解为:X = (";
for (int i = ; i < m; i++) {
cout << result[i] << ",";
}
cout << result[m] << ")" << endl;
for (int i = ; i <= m; i++) {
MaxZ += result[i] * cj[i];
}
cout << "最优值为:MzxZ = " << MaxZ;
return ;
}
程序运行结果:
c++实现单纯形法现行规划问题的求解的更多相关文章
- Excel与Google Sheets中实现线性规划求解
很久没更新过APS系列文章了,这段时间项目工作确实非常紧,所以只能抽点时间学习一下运筹学的入门知识,算是为以后的APS项目积累点基础.看了一些运筹学的书(都是科普级别的)发现原来我目前面对的很多排产. ...
- 单纯形法MATALAB实现
参考单纯形法的步骤,MATALAB中的实现如下(求极小值): 注:对于极大值的求解,只需要对目标函数添加负号,求解出来的\(X\),再带入原目标函数即可. function [ X, z ] = si ...
- 分数规划(Bzoj1486: [HNOI2009]最小圈)
题面 传送门 分数规划 分数规划有什么用? 可以把带分数的最优性求解式化成不带除发的运算 假设求max{\(\frac{a}{b},b>0\)} 二分一个权值\(k\) 令\(\frac{a}{ ...
- 【转】ACM训练计划
[转] POJ推荐50题以及ACM训练方案 -- : 转载自 wade_wang 最终编辑 000lzl POJ 推荐50题 第一类 动态规划(至少6题, 和 必做) 和 (可贪心) (稍难) 第二类 ...
- 怎么进入BAT的研发部门?
怎么进入BAT的研发部门? ======================================剑指offer+leetcode+geeksforgeeks+编程之美+算法导论====秒杀BA ...
- Hard Life
poj3155:http://poj.org/problem?id=3155 题意:最大密度子图的模板题. 题解:直接看代码. /* 题意简述一个公司有n个人,给出了一些有冲突的人的对数(u,v),所 ...
- 自学Aruba1.4-WLAN厂家魔力象限
点击返回:自学Aruba之路 1.4 自学Aruba1.4-WLAN厂家魔力象限 以下为2017<有线和无线局域网接入基础设施的魔力象限>报告: Aruba.cisco为无线领域 ...
- 自学Aruba1.3-WLAN厂家魔力象限
点击返回:自学Aruba之路 自学Aruba1.3-WLAN厂家魔力象限 以下为2017<有线和无线局域网接入基础设施的魔力象限>报告: Aruba.cisco为无线领域领导者. ...
- SVM个人学习总结
SVM个人学习总结 如题,本文是对SVM学习总结,主要目的是梳理SVM推导过程,以及记录一些个人理解. 1.主要参考资料 [1]Corres C. Support vector networks[J] ...
随机推荐
- 安卓权威编程指南 挑战练习(第26章 在 Lollipop 设备上使用 JobService)
26.11 挑战练习:在 Lollipop 设备上使用 JobService 请创建另一个 PollService 实现版本.新的 PollService 应该继承 JobService 并使用 Jo ...
- 【pic+js+gh】免费高速图床方案
本文用到的工具或网站 PicGo jsdelivr github 速度对比 Github的速度: jsdelivrCDN的速度: 下载PicGo 首先进入PicGo的下载地址 选择最新版本下载,根据自 ...
- C++走向远洋——66(十五周阅读程序)
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...
- C++走向远洋——41(深复制体验,3,)
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...
- abp框架运行——前后端分离(基于VUE)
目录 1.介绍abp 2.abp如何工作 3.运行Domo 3.1官网点击 创建Demo 3.2 配置NetCore,选择Vue 3.3 输入系统名称验证码 4.官方手册文档 5.VUE项目 6. S ...
- 记一次手机与PC同步开发Android项目
目录 -1 前言 0.0 流程简介 1.0 AS创建项目并上传GitHub 2.0 AIDE克隆GitHub项目 能力不足时曲线救国 > 3.0 termux编译AIDE目录下的项目文件 3.1 ...
- 7-42 jmu-python-找字符 (15 分)
输入一个字符串及字符,输出第一次出现该字符的位置. 输入格式: 行1:输入字符串 行2:输入一个字符 输出格式: 找到,输出对应位置,格式index=X的, X表示查找到位置 找不到,输出can't ...
- direction和writing-mode的介绍
direction介绍 属性值和兼容都很好 CSSdirection属性简单好记,属性值少,兼容性好,关键时候省心省力,是时候给大家宣传宣传,不要埋没了人家的特殊技能. Chrome Safari F ...
- 前端每日实战:151# 视频演示如何用纯 CSS 创作超能陆战队的大白
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/ReGRaO 可交互视频 此视频是可 ...
- [译]HTML&CSS Lesson7: 设置背景和渐变色
背景对网站的设计有重大的影响.它有利于建立网站的整体感觉,设置分组,分配优先级,对网站的可用性也有相当大的影响. 在CSS中,元素的背景可以是一个纯色,一张图,一个渐变色或者它们的组合.在我们决定如何 ...