c++實(shí)現(xiàn)單純形法現(xiàn)行規(guī)劃問題的求解(推薦)
在本程序中默認(rèn)該現(xiàn)行規(guī)劃問題有最優(yōu)解
針對此問題:
#include<iostream> using namespace std; int check(float *sigema, int m) { for (int i = 1; i <= m ; i++) { if (sigema[i] > 0) { return 0; } } return 1; } //此程序已經(jīng)化為標(biāo)準(zhǔn)型的線性規(guī)劃問題中,且默認(rèn)有最優(yōu)解 int main(int argc, char* argv[]) { //數(shù)據(jù)輸入部分 int m, n; cout << "請輸入變量個數(shù):"; cin >> m; cout << "請輸入不等式個數(shù):"; cin >> n; float **matrix = new float*[n + 1]; //系數(shù)矩陣 for (int i = 1; i <= n; i++) { matrix[i] = new float[m + 2]; } float *cj = new float[m + 1]; float *cB = new float[n + 1]; //基變量系數(shù) int *XB = new int[n + 1]; //用來標(biāo)注基變量x的下標(biāo) float *b = new float[n + 1]; float *sigema = new float[n + 1]; float *sita = new float[n + 1]; //初始化 for (int i = 0; i <= m; i++) { cj[i] = 0; } for (int i = 0; i <= n; i++) { cB[i] = 0; XB[i] = 0; b[i] = 0; sigema[i] = 0; sita[i] = 0; } cout << "請輸入目標(biāo)函數(shù)系數(shù)(用空格間開):" << endl; for (int i = 1; i <= m; i++) { cin >> cj[i]; } cout << "請輸入各不等式的系數(shù)和常量(用空格間開):" << endl; for (int i = 1; i <= n; i++) { cout << "不等式" << i << ": "; for (int j = 1; j <= m + 1; j++) { cin >> matrix[i][j]; } } cout << "請輸入目標(biāo)函數(shù)中基變量下標(biāo):" << endl; for (int i = 1; i <= n; i++) { cin >> XB[i]; cB[i] = cj[XB[i]]; //常量 b[i] = matrix[i][m + 1]; } //計算檢驗(yàn)數(shù) for (int i = 1; i <= m; i++) { sigema[i] = cj[i]; for (int j = 1; j <= n; j++) { sigema[i] -= cB[j] * matrix[j][i]; } } while (check(sigema, m) == 0) { //尋找入基變量 float maxn = sigema[1]; int sigema_xindex = 0; float sigema_xcoefficient = 0; for (int i = 1; i <= m; i++) { if (maxn <= sigema[i]) { maxn = sigema[i]; sigema_xindex = i; sigema_xcoefficient = cj[i]; } } //計算sita for (int i = 1; i <= n; i++) { if (matrix[i][sigema_xindex] > 0) { sita[i] = b[i] / matrix[i][sigema_xindex]; } else { sita[i] = 9999; //表示sita值為負(fù)數(shù) } } //尋找出基變量 float minn = sita[1]; int sita_xindex = 0; for (int i = 1; i <= n; i++) { if (minn >= sita[i] && sita[i] > 0) { minn = sita[i]; sita_xindex = i; } } //入基出基變換,先入基再出基 //入基操作 for (int i = 1; i <= n; i++) { if (i == sita_xindex) { XB[i] = sigema_xindex; cB[i] = sigema_xcoefficient; break; } } //出基計算 //化1 //cout << endl << "此處為化1的結(jié)果------" << endl; float mul1 = matrix[sita_xindex][sigema_xindex]; for (int i = 1; i <= m; i++) { matrix[sita_xindex][i] /= mul1; } b[sita_xindex] /= mul1; //化0 //cout << endl << "此處為化0的結(jié)果------" << endl; for (int i = 1; i <= n; i++) { if (i == sita_xindex) { continue; } float mul2 = matrix[i][sigema_xindex] / matrix[sita_xindex][sigema_xindex]; for (int j = 1; j <= m; j++) { matrix[i][j] -= (matrix[sita_xindex][j] * mul2); } b[i] -= (b[sita_xindex] * mul2); } for (int i = 1; i <= n; i++) { if (i == sita_xindex) { continue; } } for (int i = 1; i <= m; i++) { sigema[i] = cj[i]; for (int j = 1; j <= n; j++) { sigema[i] -= cB[j] * matrix[j][i]; } } } float MaxZ = 0; float *result = new float[m + 1]; for (int i = 0; i <= m; i++) { result[i] = 0; } for (int i = 1; i <= n; i++) { result[XB[i]] = b[i]; } cout << "最優(yōu)解為:X = ("; for (int i = 1; i < m; i++) { cout << result[i] << ","; } cout << result[m] << ")" << endl; for (int i = 1; i <= m; i++) { MaxZ += result[i] * cj[i]; } cout << "最優(yōu)值為:MzxZ = " << MaxZ; return 0; }
程序運(yùn)行結(jié)果:
總結(jié)
到此這篇關(guān)于c++實(shí)現(xiàn)單純形法現(xiàn)行規(guī)劃問題的求解的文章就介紹到這了,更多相關(guān)c++單純形法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
VisualStudio Community2019在安裝的過程中無法進(jìn)入安裝界面的解決方法
這篇文章主要介紹了VisualStudio Community2019在安裝的過程中無法進(jìn)入安裝界面的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03Matlab實(shí)現(xiàn)灰色預(yù)測的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何利用Matlab實(shí)現(xiàn)灰色預(yù)測,文中的示例代碼講解詳細(xì),具有一定的參考價值,感興趣的小伙伴可以了解一下2022-05-05C++設(shè)計模式編程之Flyweight享元模式結(jié)構(gòu)詳解
這篇文章主要介紹了C++設(shè)計模式編程的Flyweight享元模式結(jié)構(gòu),享元模式在實(shí)現(xiàn)過程中主要是要為共享對象提供一個存放的"倉庫"(對象池),需要的朋友可以參考下2016-03-03C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù)詳解
這篇文章主要為大家詳細(xì)介紹了C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03C++超詳細(xì)實(shí)現(xiàn)堆和堆排序過像
堆是計算機(jī)科學(xué)中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱,通常是一個可以被看做一棵完全二叉樹的數(shù)組對象。而堆排序是利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計的一種排序算法。本文將通過圖片詳細(xì)介紹堆排序,需要的可以參考一下2022-06-06