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

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

?? unit1.~pas

?? 對(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ù)類(lèi)型

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;
{-------------初始化自定義類(lèi)型的矩陣----------------}

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+1 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ù)類(lèi)型
  StringGrid2.SetFocus;
end;
{----------設(shè)置數(shù)據(jù)輸入界面-----------------------}

procedure TForm1.RadioGroup1Click(Sender: TObject);
begin
leixiing:=RadioGroup1.Items[RadioGroup1.Itemindex];
    //設(shè)置目標(biāo)函數(shù)類(lèi)型
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一区二区三区免费野_久草精品视频
日韩一区欧美二区| 国产麻豆精品视频| 国产网站一区二区| 欧美少妇bbb| 粉嫩久久99精品久久久久久夜 | 日韩欧美国产小视频| 不卡av在线网| 国产乱淫av一区二区三区| 亚洲午夜视频在线观看| 中文字幕免费在线观看视频一区| 日韩欧美在线网站| 欧美日韩在线播放| 91蜜桃网址入口| 成人午夜视频在线观看| 韩国毛片一区二区三区| 日日夜夜精品视频天天综合网| 一区二区三区在线视频播放| 欧美激情一区二区三区在线| 精品电影一区二区三区| 777精品伊人久久久久大香线蕉| 99久久久久久| 成人免费视频一区| 国产91丝袜在线18| 国内精品久久久久影院一蜜桃| 日韩精品一级二级 | 欧美一区二区三区不卡| 91九色最新地址| 色视频成人在线观看免| 91丨九色丨黑人外教| hitomi一区二区三区精品| 春色校园综合激情亚洲| 国产成人午夜片在线观看高清观看| 久久99精品网久久| 九色|91porny| 国产在线精品免费av| 国产精品自拍av| 国产精品一线二线三线| 国产成人久久精品77777最新版本| 激情综合网激情| 国产一区二区在线观看免费| 精彩视频一区二区三区| 国产福利视频一区二区三区| 国产91丝袜在线播放九色| 成人在线视频一区二区| av激情综合网| 91成人免费在线| 欧美日韩成人在线| 精品久久久久久久久久久院品网| 欧美xxxxx牲另类人与| 久久久美女毛片| 国产精品美女久久久久久久久久久| 国产精品国产三级国产aⅴ原创 | 久久精品国产77777蜜臀| 亚洲免费观看视频| 亚洲午夜在线电影| 日韩精品福利网| 久久er精品视频| 国产精品69毛片高清亚洲| 成人免费毛片高清视频| 色综合中文字幕| 91麻豆精品国产综合久久久久久| 欧美一级高清片| 久久精品一二三| 日韩理论电影院| 午夜伊人狠狠久久| 热久久久久久久| 国产乱码精品一区二区三区忘忧草| 成人一区在线看| 欧美日韩久久一区| 久久综合狠狠综合| 一区二区日韩电影| 美女网站视频久久| 99久久婷婷国产综合精品电影| 91久久精品一区二区二区| 欧美一区二区精品在线| 国产精品视频yy9299一区| 一区二区三区在线视频播放| 日韩黄色免费网站| 成人一区二区三区在线观看| 精品1区2区3区| 国产亚洲欧美日韩在线一区| 亚洲色图清纯唯美| 美女精品自拍一二三四| 99国产精品一区| 日韩欧美亚洲国产另类 | 亚洲欧美日韩在线播放| 日本成人中文字幕| 一本一道波多野结衣一区二区| 91精品一区二区三区久久久久久 | 亚洲欧美一区二区三区极速播放| 奇米色一区二区| 一本到三区不卡视频| 久久久久青草大香线综合精品| 一区二区三区成人在线视频| 国产成a人无v码亚洲福利| 8x福利精品第一导航| 《视频一区视频二区| 久久99久久精品| 欧美精品久久一区| 亚洲男女一区二区三区| 成人性视频网站| 日韩精品中文字幕一区| 亚洲成人久久影院| 91丨porny丨户外露出| 国产亚洲欧美日韩日本| 美洲天堂一区二卡三卡四卡视频| 色天使久久综合网天天| 欧美—级在线免费片| 精品中文字幕一区二区| 欧美精品1区2区| 亚洲精品视频在线观看免费| 成人激情文学综合网| 欧美tickling网站挠脚心| 午夜欧美在线一二页| 色噜噜狠狠成人中文综合| 中文字幕av一区二区三区高| 久久99精品国产麻豆婷婷洗澡| 欧美日韩一区在线| 一区二区三区不卡视频| 91麻豆视频网站| 亚洲欧美视频在线观看视频| 成人黄色在线看| 国产欧美日韩一区二区三区在线观看| 蜜臀av一级做a爰片久久| 欧美人狂配大交3d怪物一区| 午夜精品久久久久久久久久久 | 久久爱另类一区二区小说| 91精品国产欧美一区二区18| 午夜久久福利影院| 欧美精品第1页| 天天综合天天做天天综合| 欧美日本韩国一区| 日韩av不卡一区二区| 欧美一区二区三区在线看| 天天综合天天综合色| 欧美一区二区视频观看视频| 日本午夜一本久久久综合| 日韩欧美亚洲另类制服综合在线 | 国产高清无密码一区二区三区| 欧美精品一区二区三区在线播放| 精品亚洲成a人| 久久久99精品免费观看不卡| 国产主播一区二区| 久久精品欧美日韩| 成人av手机在线观看| 亚洲同性同志一二三专区| 99re成人在线| 亚洲一区二三区| 337p亚洲精品色噜噜狠狠| 久久国产欧美日韩精品| 久久久久久夜精品精品免费| 成人一级片网址| 一区二区三区中文字幕电影 | 最新成人av在线| 日本福利一区二区| 爽爽淫人综合网网站| 欧美成人三级在线| 成人激情文学综合网| 一区二区三区在线视频观看| 欧美一区二区三区视频在线 | 久久众筹精品私拍模特| eeuss国产一区二区三区| 亚洲综合一区二区三区| 欧美一区二区三区四区五区| 国产一区在线看| 亚洲欧美电影一区二区| 欧美精品日韩精品| 国产激情一区二区三区四区 | 中文字幕亚洲视频| 欧美亚洲精品一区| 激情五月激情综合网| 亚洲三级免费电影| 欧美一区二区三级| 丁香六月综合激情| 视频在线观看国产精品| 久久精品免视看| 欧美日韩国产成人在线免费| 国产综合久久久久影院| 亚洲综合区在线| 久久九九久久九九| 欧美日韩国产精品自在自线| 国产成人午夜精品影院观看视频 | 久久综合久久99| 91丨九色丨国产丨porny| 九九在线精品视频| 亚洲五月六月丁香激情| 亚洲国产精品精华液2区45| 欧美肥妇free| 成人小视频在线| 麻豆成人久久精品二区三区小说| 亚洲三级电影全部在线观看高清| 日韩精品自拍偷拍| 欧美日韩视频在线第一区| 成人精品高清在线| 激情欧美一区二区三区在线观看| 亚洲精品乱码久久久久久久久 | 欧美裸体一区二区三区| 91原创在线视频| 国产福利一区二区三区视频在线| 午夜精品久久久久久久久久|