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