日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

最佳调度问题pascal程序

發布時間:2025/3/15 编程问答 9 豆豆
生活随笔 收集整理的這篇文章主要介紹了 最佳调度问题pascal程序 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Description

假設有n個任務由k個并行工作的機器來完成。完成任務i需要的時間為Ti。試設計一個算法找出完成這n個任務的最佳調度,使得完成全部任務的時間最早。
算法設計:對任意給定的整數n和k,以及完成任務i需要的時間為Ti,i=1,2,3……n。計算完成這n個任務的最佳調度。

Input

第一行有2個正整數n和k。第2行的n個正整數是完成n個任務需要的時間。

Output

將計算的完成全部任務的最早時間

Sample Input

7 3 2 14 4 16 6 5 3

Sample Output

17



這題我是用搜索來做的

這題有點像接水問題


var n,k,tj,i:longint; b,t:array[0..10000]of longint; procedure kp(l,r:longint); var i,j,mid:longint; beginif l>=r then exit;i:=l;j:=r;mid:=t[(l+r)div 2];repeatwhile t[i]>mid do inc(i);while t[j]<mid do dec(j);if i<=j thenbegint[0]:=t[i];t[i]:=t[j];t[j]:=t[0];inc(i);dec(j);end;until i>j;kp(l,j);kp(i,r); end; procedure search(dep,time:longint); var i:longint; beginif dep>n thenif time<tj thenbegintj:=time;exit;end;if time>=tj then exit;for i:=1 to k dobeginb[i]:=b[i]+t[dep];if b[i]>time then search(dep+1,b[i]) else search(dep+1,time);b[i]:=b[i]-t[dep];end; end; beginreadln(n,k);tj:=10000;fillchar(t,sizeof(t),0);for i:=1 to n doread(t[i]);kp(1,n);fillchar(b,sizeof(b),0);search(1,0);write(tj); end.

轉載于:https://www.cnblogs.com/YYC-0304/p/9500239.html

總結

以上是生活随笔為你收集整理的最佳调度问题pascal程序的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。