题目描述
一队士兵在操场上排成一列,士兵总数为n,士兵按照队伍从前往后的顺序从1到n依次编号。每个士兵有各自的身高,第i个士兵的身高为ai。
士兵列队完毕后,将军走到队列的最前面。因为身高不一,有些士兵可能被前面身高更高的挡住了,这样将军就看不到他们。将军能看到某个士兵当且仅当他的身高严格大于他前面的所有士兵。
问将军一共能看到多少个士兵。
输入
第一行输入一个整数T(T<=100),表示测试数据的组数。每组数据第一行输入一个数n(1=<n<=10000)表示士兵的个数,第二行n个整数a1,a2,...,an(0=<ai<=1000000000),依次表示每一个士兵的身高。
| 样例输入
3
|
输出
对于每组数据,输出一行,将军能看到的士兵数。
| 样例输出
4
|
时间限制C/C++语言:1000MS其它语言:3000MS | 内存限制C/C++语言:65536KB其它语言:589824KB |
#include <iostream>
using namespace std;
int main() {
int T;
cin>>T;
while(T--)
{
int n;
int a;
cin>>n;
int temp=-1;
int sum=0;
for(int i=1;i<=n;i++)
{
cin>>a;
if(temp<a)
{
sum+=1;
temp=a;
}
}
cout<<sum<<endl;
}
return 0;
}