亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? unit1.pas

?? 用delphi實(shí)現(xiàn)運(yùn)籌學(xué)線性規(guī)劃對(duì)偶單純形法程序
?? PAS
字號(hào):
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Buttons, ExtCtrls, Grids;
 const long=100;
type
  TForm1 = class(TForm)
    panel2: TPanel;
    Memo1: TMemo;
    Panel1: TPanel;
    Label1: TLabel;
    Label2: TLabel;
    Edit1: TEdit;
    Edit2: TEdit;
    RadioGroup1: TRadioGroup;
    BitBtn1: TBitBtn;
    BitBtn2: TBitBtn;
    StringGrid2: TStringGrid;
    procedure BitBtn2Click(Sender: TObject);
    procedure BitBtn1Click(Sender: TObject);
    procedure RadioGroup1Click(Sender: TObject); 
  private
    { Private declarations }
  public
    { Public declarations }
  end;
type zengguangjuzhen=array[0..long,0..long] of real;
var
  Form1: TForm1;

implementation

{$R *.dfm}

var a:zengguangjuzhen;
    Varnum:Integer;//變量數(shù)
    Connum:Integer;//約束條件數(shù)
    leixiing:string;//返回目標(biāo)函數(shù)類型

procedure chushihua(var aa:zengguangjuzhen);
var i,j:Integer;
begin
for i:=0 to long do
  for j:=0 to long do
    aa[i,j]:=0;
end;
{-------------初始化自定義類型的矩陣----------------}

procedure  duqushuju;
var i,j:Integer;
begin
for i:=1 to  ConNum do
  for j:=1 to VarNum+1 do
    if  Form1.StringGrid2.Cells[j,i]<>'' then
      a[i,j]:=StrToFloat(Form1.StringGrid2.Cells[j,i]);
  //讀取系數(shù)矩陣和操作符
for i:=1 to ConNum do
  if Form1.StringGrid2.Cells[VarNum+2,i]<>'' then
    a[i,0]:=StrToFloat(Form1.StringGrid2.Cells[varnum+2,i]);
  //讀取限定向量

for j:=1 to VarNum do
  if Form1.StringGrid2.Cells[j,ConNum+1]<>'' then
    a[0,j]:=StrToFloat(Form1.StringGrid2.Cells[j,ConNum+1]);
  //讀取目標(biāo)函數(shù)系數(shù)
end;
{----------讀取文本框中的數(shù)據(jù)-----------------------}

function duiouhua(a:zengguangjuzhen;m,n:integer;var zengjiahang:Integer):zengguangjuzhen;
var i,j:integer;
begin
zengjiahang:=0;
for i:=1 to m do
  if a[i,n+1]=1 then
    for j:=0 to n+1 do
      a[i,j]:=-a[i,j] //大于兩邊同乘以-1
  else if a[i,n+1]=0 then
    begin
      zengjiahang:=zengjiahang+1;//所增加的行數(shù)
      for j:=0 to n+1 do
        a[m+zengjiahang,j]:=-a[i,j];//相等的增加一行
    end;
for i:=1 to m+zengjiahang do
 begin
  a[i,n+1]:=0;
  a[i,n+i]:=1;
 end;
Result:=a;
end;
{------------對(duì)偶變換--------------------------}

function panduan_d(a:zengguangjuzhen;n:Integer):Boolean;
var j:Integer;
begin
Result:=True;
for j:=1 to n do
  if a[0,j]<0 then
    begin
      Result:=False;
      Break;
    end;
end;
{---------判斷目標(biāo)函數(shù)------------------------}

function panduan_b(a:zengguangjuzhen;m:Integer):Boolean;
var i:Integer;
begin
Result:=True;
for i:=1 to m do
  if a[i,0]<-0.000001 then
    begin
      Result:=False;
      Break;
    end;
end;
{---------判斷目標(biāo)函數(shù)------------------------}

function find_r(a:zengguangjuzhen;m:Integer):Integer;
var i:Integer;
    temp_r,k:Integer;
    temp:real;
begin
temp_r:=0;
for i:=1 to m do
  if a[i,0]<-0.000001 then
    begin
      temp_r:=i;
      k:=i;
      temp:=a[i,0];
      Break;
    end;
for i:=k to m do
  if (a[i,0]<-0.000001) and (a[i,0]<temp) then
    begin
      temp_r:=i;
      temp:=a[i,0];
      Result:=i;
      Break;
    end;
Result:=temp_r;
end;
{---------尋找主行-----------------------}

function panduan_s(a:zengguangjuzhen;r:integer;n:Integer):Boolean;
var j:Integer;
begin
Result:=False;
for j:=1 to n do
  if a[r,j]<0 then
    begin
      Result:=True;
      Break;
    end;
end;
{---------判斷主列------------------------}

function find_s(a:zengguangjuzhen;r:integer;n:Integer):Integer;
var j:Integer;k:Integer;
    temp:Real;
begin
Result:=0;
temp:=0;
for j:=1 to n do
  if a[r,j]<0 then
    begin
      Result:=j;
      k:=j;
      temp:=a[0,j]/abs(a[r,j]);
      Break;
    end;
for j:=k to n do
  if (a[r,j]<0) and (a[0,j]/abs(a[r,j])<temp) then
    begin
      temp:=a[0,j]/abs(a[r,j]);
      Result:=j;
    end;
end;
{---------尋找主行-----------------------}

function diedai(a:zengguangjuzhen;r,s:integer;m,n:integer):zengguangjuzhen;
var i,j:Integer;
    temp:real;
begin
temp:=a[r,s];
for j:=0 to n do
  a[r,j]:=a[r,j]/temp;//變換主元素行
a[r,s]:=1;//避免浮點(diǎn)數(shù)運(yùn)算
for i:=0 to m  do
 begin
   temp:=a[i,s];
   if  i<>r then //變換主行以外的所有行
     begin
       for j:=0 to n do
         a[i,j]:=a[i,j]-a[r,j]*temp;
     //系數(shù)據(jù)陣,限定向量,檢驗(yàn)數(shù),目標(biāo)函數(shù)值的變換
      end;
 end;
for i:=0 to m do
  if i=r then a[i,s]:=1
  else  a[i,s]:=0;//變換主元素列
Result:=a;
end;
{---------------對(duì)應(yīng)原理第六步,完成了迭代變換-----------------------}

function  four(a:zengguangjuzhen;n:integer):Integer;
var j:Integer;
    temp:real;
begin
Result:=1;
temp:=0;
for j:=1 to n do
  if  a[0,j]<temp  then
    begin
      temp:=a[0,j];
      Result:=j;
    end;
end;
{----------對(duì)應(yīng)原理第四步,附加一行和一列的情況下選取主列-------}

function  xianxingguihua(a:zengguangjuzhen;m,n:integer;var kexing:Boolean):zengguangjuzhen;
var  i,j:Integer;
     m0:Integer;
     temp:zengguangjuzhen;
     juece:array[1..long] of Integer;//存放基變量
     r,s:Integer;
     zuiyoujie:string;
     x:array[1..long] of real;
     label 5;

begin
zuiyoujie:='你沒(méi)有輸入人和數(shù)據(jù)';
for i:=1 to long do
  begin
  juece[i]:=0;
  x[i]:=0;
end;
for i:=1 to n do
  juece[i]:=i;
chushihua(temp);
temp:=duiouhua(a,m,n,m0);
for i:=1 to m+m0 do
  begin
    temp[i,n+i]:=1;//加入松弛變量
    juece[i]:=n+i;
  end;
if leixiing='Max' then
  for j:=1 to n do
    temp[0,j]:=-temp[0,j];
//注意極大化問(wèn)題的處理
if panduan_d(temp,n+m+m0) then
  begin
5:  if panduan_b(temp,m+m0) then
       begin
        kexing:=True;
        Result:=temp;
        if leixiing='Min' THEN
          temp[0,0]:=-temp[0,0];//最小化問(wèn)題解為表格的值得相反數(shù)
        zuiyoujie:='該線性規(guī)劃的'+leixiing+'為:'
          +FormatFloat('0.######',temp[0,0])+#13+'最優(yōu)解為:';
        for i:=1 to m+m0 do
          if (juece[i]>0)  and (juece[i]<=n) then
             x[juece[i]]:=temp[i,0];
        for j:=1 to n do
          zuiyoujie:=zuiyoujie+#13+'      x'+IntToStr(j)
              +' = '+FormatFloat('0.######',x[j]);
        ShowMessage(zuiyoujie ); //最優(yōu)解
       end
    else
       begin
         r:=find_r(temp,m+m0);
         if panduan_s(temp,r,n+m+m0) then
            begin
              s:=find_s(temp,r,n+m+m0);
              juece[r]:=s;//更新決策變量
              temp:=diedai(temp,r,s,m+m0,n+m+m0);
              goto  5;
            end
         else
            begin
             ShowMessage('無(wú)可行解 '); //無(wú)可行解
             kexing:=False;
            end;
       end;
  end
else
  begin
    m0:=m0+1;
    for j:=1 to n do
      temp[m+m0,j]:=1;
    temp[m+m0,0]:=0;
    for i:=0 to m+m0 do
      for j:=0 to n+m+m0 do
        if temp[i,j]>temp[m+m0,0] then
           temp[m+m0,0]:=temp[i,j];
    temp[m+m0,0]:=temp[m+m0,0]+100;
    temp[m+m0,n+m+m0]:=1;
    juece[m+m0]:=n+m+m0;
    s:=four(temp,n+m+m0);
    r:=m+m0;
    juece[r]:=s;//更新決策變量
    temp:=diedai(temp,r,s,m+m0,n+m+m0);
    goto 5;
  end;

end;
{---------算法核心,調(diào)用小的函數(shù)和過(guò)程完成計(jì)算---------------}

procedure TForm1.BitBtn1Click(Sender: TObject);
var  i,j:integer;
begin
try
  ConNum:=strtoint(edit1.text);
  VarNum:=strtoint(edit2.text);  {輸入變量個(gè)數(shù)和約束條件個(gè)數(shù)}
except
  on EMathError do
   begin
     showmessage('輸入有誤!'+#13+'請(qǐng)確定您輸入的是整數(shù)并且沒(méi)有空格');
  //糾錯(cuò)
     exit;
  end;
end;
  stringgrid2.ColCount:=VarNum+3;
  stringgrid2.RowCount:=ConNum+2;
  stringgrid2.Cells[0,0]:='約束\變量';
  stringgrid2.Cells[0,ConNum+1]:='目標(biāo)函數(shù)';
  //表格的列數(shù)=變量數(shù)+3;第一列用作標(biāo)簽,最后兩列為運(yùn)算符及常數(shù)項(xiàng) }
  for j:=1 to VarNum do
     stringgrid2.Cells[j,0]:='X'+inttostr(j);
  //表格外觀,第一行、第一列用作標(biāo)簽.第一行顯示變量名
  for i:=1 to ConNum do
      StringGrid2.Cells[0,i]:='約束 '+IntToStr(i);
  stringgrid2.Cells[VarNum+1,0]:=  '運(yùn)算符';
    //表格第一行倒數(shù)第二列,顯示約束條件中的運(yùn)算符
  stringgrid2.Cells[VarNum+2,0]:='b';
    //表格第一行最后一列,顯示約束條件的常數(shù)項(xiàng)b
  leixiing:=RadioGroup1.Items[RadioGroup1.Itemindex];
    //設(shè)置目標(biāo)函數(shù)類型
  StringGrid2.SetFocus;
end;
{----------設(shè)置數(shù)據(jù)輸入界面-----------------------}

procedure TForm1.RadioGroup1Click(Sender: TObject);
begin
leixiing:=RadioGroup1.Items[RadioGroup1.Itemindex];
    //設(shè)置目標(biāo)函數(shù)類型
end;

procedure TForm1.BitBtn2Click(Sender: TObject);
var temp:zengguangjuzhen;
    m,n:Integer;
    jie:Boolean;//判斷有無(wú)可行解
begin
chushihua(a);//初始化變量
duqushuju;//讀取輸入數(shù)據(jù)
chushihua(temp);//初始化臨時(shí)變量
m:=Connum;
n:=Varnum;//行數(shù)和列數(shù)的傳遞
temp:=xianxingguihua(a,m,n,jie);
//程序核心,調(diào)用對(duì)偶單純形法進(jìn)行計(jì)算 
end;



end.
 

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久99久久免费精品蜜臀| 综合激情成人伊人| 欧美一区三区四区| 欧洲精品中文字幕| 91免费在线视频观看| 91一区一区三区| 色综合网色综合| 91免费观看视频在线| 91国在线观看| 色综合久久综合网97色综合| 色综合天天天天做夜夜夜夜做| 91在线观看地址| 91久久香蕉国产日韩欧美9色| 色天使色偷偷av一区二区| 色国产综合视频| 欧美日韩国产不卡| 日韩一区二区在线观看视频| 欧美va亚洲va香蕉在线| 精品国产sm最大网站| 国产偷国产偷精品高清尤物| 国产精品乱码久久久久久| 国产精品美女久久久久aⅴ| 国产精品国产三级国产普通话三级 | 日韩精品欧美精品| 午夜精品在线看| 久久国产精品99久久久久久老狼 | 91精品国产色综合久久ai换脸| 欧美一区二区三区在线视频| 久久夜色精品国产欧美乱极品| 国产亚洲成年网址在线观看| 国产精品免费丝袜| 亚洲另类色综合网站| 五月激情综合网| 九一九一国产精品| 成人免费毛片a| 欧美在线不卡视频| 在线播放中文一区| 久久久久久久国产精品影院| 亚洲人成影院在线观看| 亚洲超丰满肉感bbw| 国产一区在线看| 91麻豆国产福利精品| 在线不卡欧美精品一区二区三区| 久久久综合九色合综国产精品| 国产精品灌醉下药二区| 丝袜诱惑制服诱惑色一区在线观看| 激情欧美一区二区三区在线观看| 成人午夜免费电影| 8x8x8国产精品| 国产精品麻豆视频| 奇米色一区二区三区四区| 国产成人av电影在线| 欧美性大战久久| 国产欧美日韩精品a在线观看| 亚洲午夜久久久久久久久电影网 | 亚洲高清在线精品| 国产精品一区二区三区99| 在线看国产日韩| 欧美精品一区二区久久婷婷| 亚洲女女做受ⅹxx高潮| 国产在线精品一区二区不卡了| 色哟哟精品一区| 久久午夜老司机| 亚洲成人精品一区| bt欧美亚洲午夜电影天堂| 日韩美女一区二区三区| 亚洲精品视频一区二区| 国产盗摄精品一区二区三区在线| 欧美日韩一区小说| 中文字幕制服丝袜成人av| 日本不卡一区二区三区高清视频| 91在线观看地址| 国产日韩精品一区二区浪潮av | 亚洲午夜视频在线观看| 成人久久18免费网站麻豆 | 欧美videos大乳护士334| 一区二区三区丝袜| 丁香天五香天堂综合| 欧美sm美女调教| 三级欧美韩日大片在线看| 99国产精品国产精品毛片| 久久久高清一区二区三区| 日本中文字幕一区二区视频| 在线中文字幕不卡| 中文字幕一区二| 风间由美一区二区三区在线观看 | 亚洲综合另类小说| av中文字幕一区| 国产欧美综合在线观看第十页| 久久精品国产一区二区三| 欧美精品在线观看播放| 亚洲自拍与偷拍| 在线中文字幕一区| 亚洲欧美色图小说| 白白色 亚洲乱淫| 国产精品三级视频| 国产不卡高清在线观看视频| 亚洲精品在线电影| 国产一区91精品张津瑜| 日韩精品一区国产麻豆| 日本aⅴ亚洲精品中文乱码| 欧美日韩aaa| 亚洲成人在线观看视频| 欧美中文一区二区三区| 亚洲精品第1页| 色天天综合久久久久综合片| 最新欧美精品一区二区三区| 99视频精品在线| 亚洲另类春色校园小说| 色综合天天狠狠| 亚洲综合一二区| 欧美日本韩国一区| 日韩中文字幕亚洲一区二区va在线| 欧美日韩在线播放三区| 日韩不卡一二三区| 日韩色视频在线观看| 精品一区二区在线观看| 久久久久一区二区三区四区| 国产高清在线精品| 国产精品久久久久aaaa樱花 | 成人av中文字幕| 中文字幕亚洲一区二区av在线| 色综合天天综合网国产成人综合天| 一区二区三区四区不卡视频| 欧美日韩免费一区二区三区| 日韩成人精品在线观看| 久久综合久久久久88| 成人午夜免费av| 亚洲精品日韩一| 911精品国产一区二区在线| 麻豆91在线播放| 亚洲国产精品高清| 一本一道综合狠狠老| 亚洲一区在线观看免费观看电影高清| 欧美日韩你懂的| 国产一区高清在线| 亚洲免费观看在线观看| 欧美一区永久视频免费观看| 国产精品99久久久久久有的能看 | 亚洲精品欧美综合四区| 欧美一区二区三区白人| 成人综合婷婷国产精品久久| 亚洲乱码国产乱码精品精小说| 欧美群妇大交群的观看方式| 国产一区 二区| 亚洲综合清纯丝袜自拍| 精品国产a毛片| 色婷婷久久久亚洲一区二区三区| 蜜桃一区二区三区四区| 国产精品伦一区| 欧美一区二区三区视频免费播放 | 91在线观看地址| 六月丁香综合在线视频| 亚洲人吸女人奶水| 日韩欧美一区二区在线视频| 成人app软件下载大全免费| 亚洲第一福利一区| 国产午夜精品美女毛片视频| 欧美无砖砖区免费| 国产精品18久久久久久久久久久久 | 一本到一区二区三区| 蜜臀av亚洲一区中文字幕| 亚洲欧洲成人av每日更新| 日韩午夜精品电影| 色综合久久天天| 国产乱国产乱300精品| 同产精品九九九| 中文字幕一区二区三区四区| 日韩欧美精品三级| 欧美在线观看视频在线| 成人午夜av影视| 精品一区中文字幕| 亚洲成av人片在线| 成人欧美一区二区三区黑人麻豆| 日韩美女视频在线| 欧美色中文字幕| 成人av先锋影音| 国产乱人伦偷精品视频不卡| 石原莉奈在线亚洲二区| 亚洲精品国久久99热| 日本一区二区三区国色天香 | 成人黄色片在线观看| 久久精工是国产品牌吗| 亚洲成人av电影| 亚洲美腿欧美偷拍| 国产清纯美女被跳蛋高潮一区二区久久w| 欧美日韩一二区| 色婷婷香蕉在线一区二区| 成人av网站免费| 国产一区二区中文字幕| 麻豆精品久久久| 蜜臀国产一区二区三区在线播放 | av激情亚洲男人天堂| 国产一区二区三区在线观看免费| 日韩av中文在线观看| 亚洲成人黄色影院| 亚洲成人午夜影院| 99久久国产综合精品色伊| 国产福利一区二区| 国产专区综合网|