英国天文学家爱丁顿很喜欢骑车。据说他为了炫耀自己的骑车功力,还定义了一个“爱丁顿数”E,即满足有E天骑车超过E英里的最大整数E。据说爱丁顿自己的E等于87。
现给定某人N天的骑车距离,请你算出对应的爱丁顿数E(<=N)。
输入格式:
输入第一行给出一个正整数N(<=105),即连续骑车的天数;第二行给出N个非负整数,代表每天的骑车距离。
输出格式:
在一行中给出N天的爱丁顿数。
输入样例:10 6 7 6 9 3 10 8 2 7 8输出样例:
6
#include <cstdio>
#include <algorithm>
#include <functional>
#define MAX 100000
using namespace std;
int mail[MAX];
int main() {
int n;
scanf( "%d", &n );
for( int i = 0; i < n; i++ ) {
scanf( "%d", &mail[i] );
}
sort( mail, mail + n, greater<int>() );
int E = 0;
for( int i = 0; i < n; i++ ) {
int count = 0; // 统计当前e的数量
int now_e = n - i; // 从最大的开始遍历
for( int j = 0; j < n; j++ ) {
if( mail[j] > now_e ) {
count++;
}
else {
//printf( "%d faild\n", mail[j] );
break; // 当前数比now_e小,因为排序过了,
} // 所有后面的都要小于now_e,没有比较的必要了
if( count == now_e ) { // 找到第一次满足条件的E,退出所有循环
E = now_e;
break;
}
}
if( E ) {
break;
}
}
printf( "%d", E );
return 0;
}

本文介绍了一种基于骑行里程计算爱丁顿数的方法,并提供了一个简单的C++实现示例。爱丁顿数E定义为一个人在E天内骑行超过E英里的最大整数E。通过输入连续N天的骑行距离,程序能够找出该时间段内的爱丁顿数。

269

被折叠的 条评论
为什么被折叠?



