题目描述
陶陶家的院子里有一棵苹果树,每到秋天树上就会结出 1010 个苹果。苹果成熟的时候,陶陶就会跑去摘苹果。陶陶有个 3030 厘米高的板凳,当她不能直接用手摘到苹果的时候,就会踩到板凳上再试试。
现在已知 1010 个苹果到地面的高度,以及陶陶把手伸直的时候能够达到的最大高度,请帮陶陶算一下她能够摘到的苹果的数目。假设她碰到苹果,苹果就会掉下来。
输入格式
输入包括两行数据。第一行包含 1010 个 100100 到 200200 之间(包括 100100 和 200200)的整数(以厘米为单位)分别表示 1010 个苹果到地面的高度,两个相邻的整数之间用一个空格隔开。第二行只包括一个 100100 到 120120 之间(包含 100100 和 120120)的整数(以厘米为单位),表示陶陶把手伸直的时候能够达到的最大高度。
输出格式
输出包括一行,这一行只包含一个整数,表示陶陶能够摘到的苹果的数目。
输入输出样例
输入 #1复制
100 200 150 140 129 134 167 198 200 111 110
输出 #1复制
5
说明/提示
【题目来源】
NOIP 2005 普及组第一题
https://www.luogu.com.cn/problem/P1046
可以直接枚举所有苹果(范围满足10^8);
#include <iostream>
using namespace std;
int main() {
int a[10], s = 0, n;
for (int i = 0; i < 10; i++)
cin >> a[i];
cin >> n;
for (int i = 0; i < 10; i++) {
if (a[i] <= n + 30) {
s++;
}
}
cout << s;
return 0;
}
如果不习惯:(本蒟蒻现在也不习惯)
#include <bits/stdc++.h>
#define int long long
#define itn long long
#define double long double
#define endl '\n'
using namespace std;
int a[10], s = 0, n;
signed main() {
ios::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
for (int i = 1; i <= 10; i++) cin >> a[i];
cin >> n;
for (int i = 1; i <= 10; i++) {
if (a[i] <= n + 30) {
s++;
}
}
cout << s;
return 0;
}