用數(shù)組的方法就OK了 樓上的方法正確 只是最后printf函數(shù)拼錯罷了
公司主營業(yè)務(wù):網(wǎng)站設(shè)計制作、成都網(wǎng)站設(shè)計、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出欽北免費做網(wǎng)站回饋大家。
我完善一下
#include stdio.h
void main()
{
printf("請輸入10個整數(shù)/n");
int a[10];
int i,j,t;
for(i=0;i10;i++)
scanf("%d",a[i]);
printf("\n");
for(j=0;j9;j++)
for(i=0;i9-j;i++)
if(a[i]a[i+1])
{
t=a[i];
a[i]=a[i+1];
a[i+1]=t;
}
printf("輸出次小值%d\n輸出次大值%d\n",a[2],a[9]);
}
一次就夠了
每次保留2個值,一個最大值,一次次大值。
每次先比較次大值,大就替換,然后次大值和最大值比。
int i, n, k1, k2, k3, k4,
max, pmax, min, pmin,
num[ N ], sub[ N ];
scanf ( "%d\n", n );
scanf 函數(shù)里不要加' \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("輸入整數(shù)的總個數(shù):");
scanf ( "%d", n );
for ( i = 0; i n; i ++ )
{
printf("輸入你喜歡的整數(shù)和它的序列號: ");
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;
}
void intput(int *array,int size){
int i=0;
while(isize(scanf("%d",array+i))==1)
i++;
if(i!=size){
printf("input error\n");
exit(-1);
}
}
void output(int *array,int size){
for(int i=0;isize;i++){
if(i%3==0){
printf("\n");
}
printf("%d ",*(array+i));
}
}
int max(int *p, int size){
int *max = p;
int *second = p+1;
if(*max *second){
swap(max,second)
}
for(int i=2;isize;i++){
if(*(p+i)*second){
*second = *(p+i);
}
if(*max *second){
swap(max,second);
}
}
}
void swap(int *p,int *q){
int temp = *p;
*p = *q;
*q = temp;
}
void main(){
int array[10];
intput(array,10);
output(array);
printf("%d\n",max(array,10));
getchar();
}
新聞名稱:C語言編寫函數(shù)的次大值 最大值次大值C語言
URL標題:http://m.rwnh.cn/article16/hiejgg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、網(wǎng)站收錄、動態(tài)網(wǎng)站、網(wǎng)站改版、手機網(wǎng)站建設(shè)、
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)