#include?stdio.h
成都創(chuàng)新互聯(lián)是專業(yè)的青山網(wǎng)站建設(shè)公司,青山接單;提供網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè),網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行青山網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
#define?N?10
//求最大值函數(shù)
int?max_func(int?a[],int?n)
{
int?i,max;
for(max=a[0],i=1;iN;i++)??//初始默認(rèn)最大值為a[0],遍歷數(shù)組元素
if(maxa[i])??//如果當(dāng)前最大值當(dāng)前數(shù)組元素,則將該元素賦值給max
max=a[i];
return?max;
}
//求最小值函數(shù)
int?min_func(int?a[],int?n)
{
int?i,min;
for(min=a[0],i=1;iN;i++)??//初始默認(rèn)最小值為a[0],遍歷數(shù)組元素
if(mina[i])??//如果當(dāng)前最小值當(dāng)前數(shù)組元素,則將該元素賦值給min
min=a[i];
return?min;
}
int?main()
{
int?arr[N],i;
int?max,min;
for(i=0;iN;i++)??//輸入10個(gè)數(shù)組元素
scanf("%d",arr[i]);
max=max_func(arr,N);??//調(diào)用max_func()函數(shù)
min=min_func(arr,N);??//調(diào)用min_func()函數(shù)
printf("最大值=%d\n最小值=%d\n",max,min);??//輸出結(jié)果
return?0;
}
1)問題出在minmax函數(shù),這個(gè)函數(shù)找到的最大值和最小值沒有返回。
2)雖然你定義了最大值和最小值為全局變量,但是在minmax函數(shù)的調(diào)用參數(shù)中你又定義了同名變量,這樣在minmax函數(shù)內(nèi)部實(shí)際使用的是局部變量。
3)最簡單的方法,直接把minmax函數(shù)的后兩個(gè)輸入?yún)?shù)去掉。
#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("有幾個(gè)數(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("有幾個(gè)數(shù):");
scanf("%d",n);
mm=maxmin(n);
printf("其中最大的數(shù)是:%d\n最小的數(shù)是:%d\n",mm,min);
return 0;
}
#includestdio.h
int Max(int a[],int n)
{
int s,max=0;
for(s=1;s=9;s++)//逐個(gè)循環(huán)進(jìn)行比較大小找出最大值
{
if(a[max]a[s])
max=s;
}
return max;
}
int Min(int a[],int c)
{
int d,min=0;
for(d=1;d=9;d++)
{
if(a[min]a[d])
min=d;
}
return min;
}
main()
{
int a[10],i,n;
printf("請(qǐng)任意輸入10個(gè)數(shù)字\n");
for(i=0;i10;i++)
scanf("%d",a[i]);
int larger;
larger=Max(a,10);//調(diào)用Max函數(shù)找出最大值并賦值
printf("最大數(shù)為%d\n",a[larger]);
int smaller;
smaller=Min(a,10);
printf("最小數(shù)為%d\n",a[smaller]);
n=a[larger];
a[larger]=a[smaller];
a[smaller]=n;
for(i=0;i10;i++)
printf("%2d",a[i]);
}
思路:首先設(shè)置最大最小的值都是數(shù)組第一個(gè)數(shù),然后遍歷數(shù)組,出現(xiàn)比當(dāng)前最大值大的,修改最大值為這個(gè)數(shù)。出現(xiàn)比最小值小的,修改最小值為這個(gè)數(shù)。
代碼
#include?stdio.h
//為了方便返回,使用結(jié)構(gòu)體存儲(chǔ)最大值和最小值
typedef?struct?{
int?Max;
int?Min;
}MaxMin;??????
//函數(shù)參數(shù)array:數(shù)組,length:數(shù)組長度。
//這里其實(shí)可以把最大值最小值作為指針傳進(jìn)去的。??
MaxMin?GetMaxMin(int?*array,?int?length)
{
int?i;
MaxMin?maxMin;
if?(length?=?0)
return?maxMin;
//初始化最大值和最小值為數(shù)組第一個(gè)數(shù)
maxMin.Max?=?array[0];
maxMin.Min?=?array[0];
for?(i?=?0;?i??length;?i++)?{
if?(array[i]?=?maxMin.Max)????????
maxMin.Max?=?array[i];????????//比當(dāng)前最大值大,修改最大值
if?(array[i]?=?maxMin.Min)
maxMin.Min?=?array[i];????????//比當(dāng)前最小值小,修改最小值
}
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. 運(yùn)行結(jié)果
任意輸入10個(gè)數(shù),求其中的最大值和最小值的源代碼如下:
#includestdio.h
#define SIZE_MAX 30
int max(int b[],int n);
int min(int b[],int n);
int main(void)
{
int ?a[SIZE_MAX],b,c,i,m;
printf("任意多個(gè)數(shù),判斷最大值和最小值:\n");
printf("輸入一個(gè)數(shù),表示你想比較多少個(gè)數(shù)字:\n");
scanf("%d",m);
printf("你輸入了%d個(gè)數(shù)\n",m);
printf("請(qǐng)你輸入%d個(gè)數(shù)\n",m);
for(i=0;im;i++)
{
scanf("%d",a[i]);
}
b=max(a,m);
c=min(a,m);
printf("你輸入的%d分別是:\n",m);
for(i=0;im;i++)
{
printf("%d\n",a[i]);
printf("最大數(shù)是:%d\n",b);
printf("最小數(shù)是:%d\n",c);
return 0;
}
擴(kuò)展資料
1、如果一個(gè)函數(shù)確定無需傳入任何參數(shù),那么用void限定是一個(gè)不錯(cuò)的選擇。函數(shù)沒有聲明返回值時(shí),編譯器默認(rèn)其返回值為int。
2、main函數(shù)的返回值最終會(huì)作為程序的退出狀態(tài),而一旦聲明為void,在程序退出后,想要獲取其退出狀態(tài)也就不可以了。因此不建議其返回值為void。
分享名稱:c語言取最大最小值函數(shù) c語言函數(shù)求最大最小值
文章源于:http://jinyejixie.com/article24/hpcpje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、面包屑導(dǎo)航、關(guān)鍵詞優(yōu)化、網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)