试题 算法提高 第二大整数(C语言)

  • 资源限制
    时间限制:1.0s 内存限制:512.0MB
  • 问题描述
      编写一个程序,读入一组整数(不超过20个),当用户输入0时,表示输入结束。然后程序将从这组整数中,把第二大的那个整数找出来,并把它打印出来。说明:(1)0表示输入结束,它本身并不计入这组整数中。(2)在这组整数中,既有正数,也可能有负数。(3)这组整数的个数不少于2个。
      输入格式:输入只有一行,包括若干个整数,中间用空格隔开,最后一个整数为0。
      输出格式:输出第二大的那个整数。
      输入输出样例
  • 样例输入
    5 8 -12 7 0
  • 样例输出
    7

满分代码如下:

#include<stdio.h>
int main(){
    int a[20],n,i,j,t,m=0;
    while(scanf("%d",&n)&&n){
        a[m++]=n;
    }
    for(i=0;i<m-1;i++){
        for(j=i+1;j<m;j++){
            if(a[i]<a[j]){
                t=a[i];a[i]=a[j];a[j]=t;
            }
        }
    }
    printf("%d",a[1]);
    return 0;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。