从品牌网站建设到网络营销策划,从策略到执行的一站式服务
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]就可以了
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图