排队接水pascal程序
題意
找出這n個(gè)人排隊(duì)的一種順序,使得n個(gè)人的平均等待時(shí)間最小。
分析
打水的時(shí)候花費(fèi)時(shí)間越少的人越先打,那么所有人的等待時(shí)間之和就會(huì)最小,所以我們要先排序,再計(jì)算總時(shí)間
var
a,b:array[0..50000]of longint;
n,i,j,w:longint;
tj:real;
begin
? ? readln(n);
? ? for i:=1 to n do
? ? begin
? ? ? ? read(a[i]);
? ? ? ? b[i]:=i;
? ? end;
? ? for i:=1 to n-1 do
? ? begin
? ? ? ? for j:=i+1 to n do
? ? ? ? if a[i]>a[j] then
? ? ? ? begin
? ? ? ? ? ? a[0]:=a[i];a[i]:=a[j];a[j]:=a[0];
? ? ? ? ? ? b[0]:=b[i];b[i]:=b[j];b[j]:=b[0];
? ? ? ? end;
? ? end;
? ? tj:=0;
? ? for i:=1 to n do
? ? write(b[i],' ');
? ? writeln;
? ? w:=0;
? ? for i:=n-1 downto 0 do
? ? begin
? ? ? ? inc(w);
? ? ? ? tj:=tj+a[w]*i;
? ? end;
? ? write((tj/n):0:2);
end.
轉(zhuǎn)載于:https://www.cnblogs.com/YYC-0304/p/9500215.html
總結(jié)
以上是生活随笔為你收集整理的排队接水pascal程序的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: A*B Problem
- 下一篇: 快速排序pascal程序