1)問題出在minmax函數(shù),這個函數(shù)找到的最大值和最小值沒有返回。
創(chuàng)新互聯(lián)公司2013年至今,先為突泉等服務建站,突泉等地企業(yè),進行企業(yè)商務咨詢服務。為突泉企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務解決您的所有建站問題。
2)雖然你定義了最大值和最小值為全局變量,但是在minmax函數(shù)的調用參數(shù)中你又定義了同名變量,這樣在minmax函數(shù)內部實際使用的是局部變量。
3)最簡單的方法,直接把minmax函數(shù)的后兩個輸入?yún)?shù)去掉。
思路:首先設置最大最小的值都是數(shù)組第一個數(shù),然后遍歷數(shù)組,出現(xiàn)比當前最大值大的,修改最大值為這個數(shù)。出現(xiàn)比最小值小的,修改最小值為這個數(shù)。
代碼
#include?stdio.h
//為了方便返回,使用結構體存儲最大值和最小值
typedef?struct?{
int?Max;
int?Min;
}MaxMin;??????
//函數(shù)參數(shù)array:數(shù)組,length:數(shù)組長度。
//這里其實可以把最大值最小值作為指針傳進去的。??
MaxMin?GetMaxMin(int?*array,?int?length)
{
int?i;
MaxMin?maxMin;
if?(length?=?0)
return?maxMin;
//初始化最大值和最小值為數(shù)組第一個數(shù)
maxMin.Max?=?array[0];
maxMin.Min?=?array[0];
for?(i?=?0;?i??length;?i++)?{
if?(array[i]?=?maxMin.Max)????????
maxMin.Max?=?array[i];????????//比當前最大值大,修改最大值
if?(array[i]?=?maxMin.Min)
maxMin.Min?=?array[i];????????//比當前最小值小,修改最小值
}
return?maxMin;
}
//主函數(shù)測試
int?main()?{
int?length;
int?i;
int?*array;
printf("input?length?of?array:");
scanf("%d",?length);
array?=?(int?*)malloc(sizeof(int)*length);
for?(i?=?0;?i??length;?i++)?{
printf("input?data?of?array(index?%d):",?i?+?1);
scanf("%d",?array?+?i);
}
MaxMin?maxMin?=?GetMaxMin(array,?length);
printf("Max:%d,Min:%d",?maxMin.Max,?maxMin.Min);
return?0;
}
3. 運行結果
用指針求含有十個元素的數(shù)組最大值和最小值
主函數(shù)參考
int main()
{
int a[10],i,maxnum,minnum;
for(i=0;i10;i++)
scanf("%d",a[i]);
FindMaxandMin(a,10,maxnum,minnum);
printf("%d %d",maxnum,minnum);
}
輸入格式:
數(shù)組
輸出格式:
最大值 最小值
輸入樣例:
1 2 3 5 4 6 7 8 9 10
輸出樣例:
10 1
擴展資料
#include
int main()
{
int a[3];
int i,j,temp;
printf("請輸入3個數(shù):");
for(i=0;i scanf("%d",a[i]);
for(i=0;i for(j=0;j if(a[j]a[j+1])
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
printf("最大值%d最小值%d",a[2],a[0]);
return 0;
}
參考資料:百度百科 - C語言
#includestdio.h
int?max(int?n)
{int?i,x,f;
scanf("%d",f);
for(i=1;in;i++)
{scanf("%d",x);
if(xf)f=x;
}
return?f;
}
int?main()
{int?n;
printf("有幾個數(shù):");
scanf("%d",n);
printf("其中最大的數(shù)是:%d\n",max(n));
return?0;
}
#includestdio.h
int min;
int maxmin(int n)
{int i,x,f;
scanf("%d",f);
min=f;
for(i=1;in;i++)
{scanf("%d",x);
if(xf)f=x;
else if(xmin)min=x;
}
return f;
}
int main()
{int n,mm;
printf("有幾個數(shù):");
scanf("%d",n);
mm=maxmin(n);
printf("其中最大的數(shù)是:%d\n最小的數(shù)是:%d\n",mm,min);
return 0;
}