鱼C论坛

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

[已解决]谁来帮帮我

[复制链接]
发表于 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-11-5 04:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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