洛谷P1223-排队接水

2019.7.19


有n个人在一个水龙头前排队接水,假如每个人接水的时间为Ti,请编程找出这n个人排队的一种顺序,使得n个人的平均等待时间最小。

输入格式
输入文件共两行,第一行为n;第二行分别表示第1个人到第n个人每人的接水时间T1,T2,…,Tn,每个数据之间有1个空格。

输出格式
输出文件有两行,第一行为一种排队顺序,即1到n的一种排列;第二行为这种排列方案下的平均等待时间(输出结果精确到小数点后两位)。

输入输出样例
输入
10
56 12 1 99 1000 234 33 55 99 812
输出
3 2 7 8 1 4 9 6 10 5
291.90
说明/提示
n<=1000

ti<=1e6,不保证ti不重复

当ti重复时,按照输入顺序即可(sort是可以的)


我的思路:

题目要求使得n个人的平均等待时间最小,即需要时间少的最先接水最后这n个人的平均等待时间就最小,将这n个人所需的时间从小到大排序(用sort函数https://www.cnblogs.com/TX980502/p/8528840.html),然后依次求等待时间即可;
1.用一个结构体存储变量,a是所用时间,b是对应的序号,方便排序后还可以输出相应的序号;
2.当第i个人接水时,只有n-i个人在等待这第i个人需要的时间,所以相应的的等待时间是a[i].a*(n-i)(i是从1开始的)。


#include <iostream>
#include <algorithm>
#include <cstdio>
using namespace std;
struct node
{
    int a;
    int b;
}a[1005];
bool cmp(node a, node b)
{
    if(a.a != b.a)  return a.a<b.a;
    else            return a.b<b.b;
}
int main()
{
    int n;
    double ans = 0;
    cin >> n;
    for(int i=1; i<=n; i++)
    {
        cin >> a[i].a;
        a[i].b = i;
    }   
    sort(a+1,a+1+n,cmp);
    for(int i=1; i<=n; i++)
        ans += a[i].a * (n-i);
    ans /= n;
    for(int i=1; i<=n; i++)
        cout << a[i].b << " ";
    cout << endl;
    printf("%.2f\n", ans);
    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容