lijinnaduibuqi 发表于 2018-9-12 22:20:03

谁来帮帮我

有n个人在处理不同的事物,已知每个人需要处理的时间为ti,(0<t<n),请求出每个人排队时间总和最小的时间。

输入n的整数组成的空格隔开字符串

输出n个人排队的最小时间总和
例如输入5 10 8 7 输出67

claws0n 发表于 2018-9-12 23:05:41

久等了time_list = "5 10 8 7"
a = time_list.split()
b =
b.sort()

work_time = 0
for i in range(len(b)):
    work_time += b


wait_time = 0
for i in range(1,len(b)):
    for j in range(i):
      wait_time += b

total_time = work_time + wait_time
print(total_time)

lijinnaduibuqi 发表于 2018-9-13 08:32:02

谢谢你,大谢

claws0n 发表于 2018-9-13 08:48:13

lijinnaduibuqi 发表于 2018-9-13 08:32
谢谢你,大谢

^_^ 还以为来不及。只有一题?题目的逻辑要去理解~

Mountain_gs 发表于 2018-9-13 10:36:20

python的代码我不会写,这里给个思路。
假设排队的队列为ti,那么每个人都必须等他前面的人把事情昨晚,这样:
第一个人工作时有n-1个人在等,第二个人工作时有n-2个人在等,以此类推,等待的总时间为
Twait=Σti*(n-1-i) (i∈【0,n-2】);
Twork=Σti (i∈【0,n-1】);#include<iostream>
#include<algorithm>
using namespace std;

int main()
{
        int T=0;
        int a[] = { 5,10,8,7 };
        int length = sizeof(a) / sizeof(int);
        sort(a, a + length);
        for (int i = 0; i < length; i++)
        {
                T = T + a * (length - i);
        }
        cout << T << endl;
        system("pause");
        return 1;
}
T=Σti*(n-i) (i∈【0,n-1】);
这样计算时只需要一个循环,时间复杂度为O(n).
页: [1]
查看完整版本: 谁来帮帮我