十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
int i, n, k1, k2, k3, k4,
创新互联 - 联通机房服务器托管,四川服务器租用,成都服务器租用,四川网通托管,绵阳服务器托管,德阳服务器托管,遂宁服务器托管,绵阳服务器托管,四川云主机,成都云主机,西南云主机,联通机房服务器托管,西南服务器托管,四川/成都大带宽,成都机柜租用,四川老牌IDC服务商
max, pmax, min, pmin,
num[ N ], sub[ N ];
scanf ( "%d\n", n );
scanf 函数里不要加' \n ' 和别的一些特殊符号,最好什么都别乱加,直接使用%d %f 等一些格式输入符。
# include stdio.h
# define N 30
int main ( )
{
int i, n, k1, k2, k3, k4,
max, pmax, min, pmin,
num[ N ], sub[ N ];
printf("输入整数的总个数:");
scanf ( "%d", n );
for ( i = 0; i n; i ++ )
{
printf("输入你喜欢的整数和它的序列号: ");
scanf ( "%d%d",num[ i ], sub[ i ] );
}
max = min = pmax = pmin = num[ 0 ];
k1 = k2 = k3 = k4 = sub[ 0 ];
for ( i = 1; i n; i ++ ) {
if ( max = num[ i ] ) { //最大值
max = num[ i ];
k1 = sub[ i ];
}
if ( min =num[ i ] ) { //最小值
min = num[i];
k3 = sub[i];
}
if ( pmax =num[ i ] num[ i ] !=max ) { //次大值
pmax = num[ i ];
k2 = sub[ i ];
}
if ( pmin = num[ i ] num[ i ] !=min ) { //次小值
pmin = num[ i ];
k4 = sub[ i ];
}
}
printf ( "max=%d,maxNum=%d\n pmax=%d,pmaxNum=%d\nmin=%d,minNum=%d \npmin=%d,pminNum=%d\n", max, k1, pmax, k2, min, k3, pmin, k4 );
return 0;
}
简单的办法就是遍历啊,第一遍找到最大值,然后将最大值剔除或者做上标记,然后遍历第二遍找剩余数的最大值,那么找到的就是次大值了。
没有时间写源程序,说说思想吧
设数组a[2],开始时赋值a[0]=a[1]=0
让a[1]依次和要求次大数的数组中元素比较,如果a[1]小于被比较的元素
{
a[0]=a[1];
a[1]=这个被比较的元素的值;
}
最后输出a[0]就可以了