资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
编写一个程序,读入一组整数(不超过20个),当用户输入0时,表示输入结束。然后程序将从这组整数中,把第二大的那个整数找出来,并把它打印出来。说明:(1)0表示输入结束,它本身并不计入这组整数中。(2)在这组整数中,既有正数,也可能有负数。(3)这组整数的个数不少于2个。
输入格式:输入只有一行,包括若干个整数,中间用空格隔开,最后一个整数为0。
输出格式:输出第二大的那个整数。
输入输出样例
样例输入
5 8 -12 7 0
样例输出
7
分析:
题目相对简单,根据题目要求,定义最大符合要求的数组,一直循环输入,当输入为0时,跳出输出。然后利用排序得出第二大的数据。
#include<iostream>
using namespace std;
int main()
{
int a[20];
int i;
for(i=0;;i++)
{
cin>>a[i];
if(a[i]==0)
break;
}
for(int t=0;t<i;t++)
{
for(int j=0;j<i-t-1;j++)
{
if(a[j]<a[j+1])
swap(a[j],a[j+1]);
}
}
cout<<a[1];
return 0;
}
注意这里,题目中有了一个要求,0作为结束标着,本身不计入结果,但是实质上多运算了一个数据0,但是结果是没有影响的,如果要计算最小的数据时候,就需要对运算数组区间进行一下调整。
有问题请下方评论,转载请注明出处,并附有原文链接,谢谢!如有侵权,请及时联系。