孩子们,我回来了(写了个简单题)

P1223 排队接水

时间限制: 1.00s    内存限制: 125.00MB

题目描述

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

一个人的等待时间不包括他的接水时间。

如果两个人接水的时间相同,编号更小的人应当排在前面。

输入格式

第一行为一个整数 n

第二行 n 个整数,第 i 个整数 Ti​ 表示第 i 个人的接水时间 Ti​。

输出格式

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

#include <iostream>
#include <algorithm>
#include <vector>
#include <iomanip>
using namespace std;
int main(){
    int n;
    cin>>n;
    vector<int> time(n);
    vector<int> order(n);
    for(int i = 0;i < n;i++){
        cin>>time[i];
        order[i]=i+1;
    }
    for(int i = 0;i<n-1;i++){
        for(int j = 0;j<n-1-i;j++){
            if(time[j]>time[j+1]){
                swap(order[j],order[j+1]);
                swap(time[j],time[j+1]);
            }
        }
    }
    double sum = 0;
    for(int i = 0;i < n;i++){
        cout<<order[i]<<" ";
        sum+=(n-i-1)*time[i];
    }
    cout<<fixed<<setprecision(2);
    cout<<endl<<sum/n;
    return 0;
    
}

评论

  1. 91cyl
    4 周前
    2026-2-04 23:38:16

    👍

  2. 博弈论
    4 周前
    2026-2-04 23:41:47

    太敷衍了吧,这篇所谓的“解题教程”怕不是随便复制粘贴交差的?代码光秃秃连一行注释都没有,冒泡排序的逻辑、等待时间计算公式的原理半个字不提,合着是默认看的都是神仙能秒懂?标注“孩子们”的受众,结果连最基础的题目解读、核心思路(短时间先接水的贪心逻辑)都懒得说,甚至连个测试用例都没有,谁知道这代码能不能跑、有没有bug?
    作为教学类内容,连“教会人”的最基本底线都达不到,只做了“贴题+贴代码”的最低级操作,敷衍得明明白白。与其发这种毫无价值的东西浪费大家时间,不如好好打磨内容,要么就别出来误人子弟!

    • 老电工 Chen
      博弈论
      4 周前
      2026-2-05 15:13:41

      谁家AI

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇