问题描述:

     设有n 个顾客同时等待一项服务。顾客i需要的服务时间为ti, 1<=i <= n 。应如何安排n个顾客的服务次序才能使平均等待时间达到最小?平均等待时间是n 个顾客等待服务时间的总和除以n。

简单的贪心思想

 代码:

复制代码
#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
   int n;
   cin>>n;
   int s[n];
   for(int i=0;i<n;i++)
   {
       cin>>s[i];
   }                //输入
   sort(s,s+n);        //排序,升序
   double sum=0;
   for(int i=0;i<n;i++)
   {
       sum+=s[i]*(n-i);    //等待时间总和
   }
   cout<<sum/n<<endl;    //平均值
}
复制代码

 

 posted on   几缕清风依旧  阅读(1041)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 内存占用高分析
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
阅读排行:
· 20250116 支付宝出现重大事故 有感
· 一个基于 Roslyn 和 AvalonEdit 的跨平台 C# 编辑器
· 2025 最佳免费商用文本转语音模型: Kokoro TTS
· 海康工业相机的应用部署不是简简单单!?
· 在 .NET Core中如何使用 Redis 创建分布式锁
点击右上角即可分享
微信分享提示