最优服务次序问题

探讨了如何通过排序算法确定最优服务次序以最小化平均等待时间的问题。介绍了问题背景及具体实现方法,包括输入输出格式,并给出了一段C语言代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最优服务次序问题

Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^

题目描述

设有n 个顾客同时等待一项服务。顾客i需要的服务时间为t  i,1≤i≤n。应如何安排n个顾客的服务次序才能使平均等待时间达到最小?平均等待时间是n 个顾客等待服务时间的总和除以n。
对于给定的n 个顾客需要的服务时间,计算最优服务次序。

输入

输入数据的第一行是正整数n(n≤1000),表示有n 个顾客。接下来的1行中,有n 个正整数,表示n 个顾客需要的服务时间。

输出

输出一个实数,保留2位小数,表示计算出的最小平均等待时间。

示例输入

10
56 12 1 99 1000 234 33 55 99 812

示例输出

532.00

#include<stdio.h>    
int main()    
{    
    int i,j,n,m,k,t,a[1000];    
    double b;    
    scanf("%d",&n);    
    for(i=0;i<n;i++)    
        scanf("%d",&a[i]);    
    for(i=0;i<n-1;i++)    
    {    
        k=i;    
        for(j=i+1;j<n;j++)    
            if(a[k]>a[j])    
                k=j;    
            if(k!=i)    
            {    
                t=a[k];    
                a[k]=a[i];    
                a[i]=t;    
            }    
    }    
    m=0;    
    for(i=0;i<n;i++)    
        m+=a[i]*(n-i);    
    b=1.0*m/n;    
    printf("%.2lf\n",b);    
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值