#include <stdio.h>
int main()
{
int max1,n,max2=0;
int num[10];
while(scanf("%d",&n)!=EOF){
for(int i=0;i<n;i++)
scanf("%d",&num[i]);
max1=num[0];
for(int i=0;i<n;i++)
{
if(max1=num[0])
{
if(max1<=num[i])
max2=max1;
max1=num[i];
}
else if(max2<=num[i])
{
max2=num[i];
}
}
printf("%d\n",max2);
}
return 0;
}
题目描述
有同学觉得求最大值和最小值太简单了,于是想挑战一下第二大数,这个有点难度咯。
说明一下:万一参与比较的几个数都一样大:-( ,例如7 7 7 7,那就输出-1吧 (:3_I /)
输入
在输入的每一行中,第一个数n表示该行有几个数字。n之后接一个空格,然后是参与大小比较的数字。
2 <= n <= 100,参与比较的数字都在32位有符号整型范围以内
输出
输出参与比较的数字中的第二大数字
样例输入
4 1 2 3 4
3 1 2 1
4 2 2 2 2
3 2 2 1
样例输出
3
1
-1
1
但我写的代码输出之后是1 1 2 2
而且我也不会写当数字都一样的情况,麻烦哪位哥哥姐姐会编程的救救孩子(╥╯﹏╰╥)ง