Run ID | 作者 | 问题 | 语言 | 测评结果 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|
34442 | 老方 | [贪心算法]排队接水 | C++ | 通过 | 0 MS | 252 KB | 492 | 2023-12-22 18:47:28 |
#include<bits/stdc++.h> using namespace std; struct s{ int num,time; }; int main(){ int n; cin>>n; s ns[n]; for(int i=0;i<n;i++){ cin>>ns[i].time; ns[i].num=i+1; } for(int i=0;i<n;i++){ int max=i; for(int j=i;j<n;j++){ if(ns[j].time<ns[max].time)max=j; } s t=ns[max]; ns[max]=ns[i]; ns[i]=t; } int sum=0; for(int i=0;i<n;i++){ cout<<ns[i].num<<' '; sum+=ns[i].time*(n-1-i); } cout<<endl; printf("%.2f",sum*1.0/n); return 0; }