鱼C论坛

 找回密码
 立即注册
查看: 2785|回复: 4

[已解决]谁来帮帮我

[复制链接]
发表于 2018-9-12 22:20:03 From FishC Mobile | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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

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

输出n个人排队的最小时间总和
例如输入5 10 8 7 输出67
最佳答案
2018-9-12 23:05:41
久等了
  1. time_list = "5 10 8 7"
  2. a = time_list.split()
  3. b = [int(x) for x in a]
  4. b.sort()

  5. work_time = 0
  6. for i in range(len(b)):
  7.     work_time += b[i]


  8. wait_time = 0
  9. for i in range(1,len(b)):
  10.     for j in range(i):
  11.         wait_time += b[j]

  12. total_time = work_time + wait_time
  13. print(total_time)
复制代码
IMG20180912210730.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-9-12 23:05:41 | 显示全部楼层    本楼为最佳答案   
久等了
  1. time_list = "5 10 8 7"
  2. a = time_list.split()
  3. b = [int(x) for x in a]
  4. b.sort()

  5. work_time = 0
  6. for i in range(len(b)):
  7.     work_time += b[i]


  8. wait_time = 0
  9. for i in range(1,len(b)):
  10.     for j in range(i):
  11.         wait_time += b[j]

  12. total_time = work_time + wait_time
  13. print(total_time)
复制代码
1.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-9-13 08:32:02 From FishC Mobile | 显示全部楼层
谢谢你,大谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-13 08:48:13 From FishC Mobile | 显示全部楼层
lijinnaduibuqi 发表于 2018-9-13 08:32
谢谢你,大谢

^_^ 还以为来不及。只有一题?题目的逻辑要去理解~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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】);
  1. #include<iostream>
  2. #include<algorithm>
  3. using namespace std;

  4. int main()
  5. {
  6.         int T=0;
  7.         int a[] = { 5,10,8,7 };
  8.         int length = sizeof(a) / sizeof(int);
  9.         sort(a, a + length);
  10.         for (int i = 0; i < length; i++)
  11.         {
  12.                 T = T + a[i] * (length - i);
  13.         }
  14.         cout << T << endl;
  15.         system("pause");
  16.         return 1;
  17. }
复制代码

T=Σti*(n-i) (i∈【0,n-1】);
这样计算时只需要一个循环,时间复杂度为O(n).
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-22 09:46

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表