當前位置:首頁 » 編程語言 » c語言子函數
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言子函數

發布時間: 2022-01-12 11:23:17

c語言 子函數的問題

m=15,這個m是全局變數,在主函數中有效
m=3,這個m是局部變數,在函數func內有效

func(4,7)=5*7-3=32
主程序中第一個輸出語句的輸出是32,15,第二個輸出語句的輸出是4*7%15,即13

⑵ C語言中子函數中的子函數如何跳到主函數

函數都是並列關系,不存在一個嵌套另一個的問題,只能是一個調用另一個,在其中又調用另一個,一層層調用,正常情況都只有一個返回出口,也是一層一層返回,不能跳過。

⑶ 一、要求以C語言,編寫幾個子函數(至少4個子函數)

#include<stdio.h>
floatsum(floatx,floaty){
returnx+y;
}
floatquotient(floatx,floaty){
returnx/y;
}
floatproct(floatx,floaty){
returnx*y;
}
floatdifferrent(floatx,floaty){
returnx-y;
}
intmain(void){
floata,b;
a=12;
b=2;
printf("sumis%f ",sum(a,b));
printf("quotientis%f ",quotient(a,b));
printf("proctis%f ",proct(a,b));
printf("differrentis%f ",differrent(a,b));
}

函數的知識和函數的調用
上面的代碼是函數的嵌套使用。函數作為另一個函數(printf)的參數

⑷ c語言子函數的調用格式是什麼

調用子函數的目的是程序代碼的可讀性,如果一個函數超過了20行那就考慮調用子函數來完成了。

⑸ C語言里子函數可以調用子函數嗎

可以的。

C語言規定,任意函數均可以嵌套調用。所以子函數可以調用其它子函數,也可以調用自身。

intfunc(inta)
{
if(a==0)return0;
returnfunc(a-1)+a;
}

這樣調用自身的稱為遞歸調用。


又如:

intfa(inta)
{
returna*a;
}

intfb(inta)
{
returnfa(a)+fa(a);
}

這就是不同函數調用的例子。

⑹ C語言中的子函數和主函數有什麼聯系啊它們是怎麼編寫的

在C語言中主函數調用子函數,子函數被主函數調用,這就是它們之間的聯系。編寫函數主要有以下步驟,首先對函數進行定義,語法格式為:

類型說明符 函數名 (含類型說明的形式參數表)

{

語句序列

}

形式參數的作用是實現主函數和被調函數之間的聯系。通常將函數所處理的數據、影響函數功能的因素或函數處理的結果作為形參。

然後還要確定函數的返回值及類型,格式為:

return 表達式;

這個語句的另一個作用是結束當前函數的執行。一個函數可以不將任何值返回主函數,此時它的類型標識符為void,可以不寫return語句,也可以寫一個不帶表達式的return;語句。

(6)c語言子函數擴展閱讀

C語言編程書寫規則:

1、一個說明或一個語句佔一行。

2、用{} 括起來的部分,通常表示了程序的某一層次結構。{}一般與該結構語句的第一個字母對齊,並單獨佔一行。

3、低一層次的語句或說明可比高一層次的語句或說明縮進若干格後書寫。以便看起來更加清晰,增加程序的可讀性。在編程時應力求遵循這些規則,以養成良好的編程風格。

⑺ c語言的子函數問題

c 是以拷貝的形式放在了函數f(STU e)中的e中。不會影響c的值。
樓主網路下傳值,傳址。

⑻ C語言中一個子函數怎麼調用另一個子函數的運算

方法很多。

主要是要將不同類型傳遞給fun2處理。

最簡單float類型最大,fun2的參數類型就定義為float,然後運算結果返回float類型。在main函數用a3,b3,c3接收的時候強轉型。

另一種方法,把變數都轉換成一種類型傳遞。這里用union共用體類型就比較適合。還方便擴展,如果想添加其他類型還可以在union里添加。

我這里代碼就用第二種方法寫。

#include <stdio.h>

typedef union data{

char c;

int i;

float f;

}DA;

void fun1(void);

DA fun2(DA n1,DA n2,int nType);//nType=1:char類型。nType=2:int類型。nType=3:float類型。

int main()

{

fun1();

return 0;

}

void fun1(void)

{

char a1=1,a2=2;

int b1=100,b2=300;

float c1=5.1,c2=6.8;

DA n1,n2;

n1.c=a1,n2.c=a2;

char a3=fun2(n1,n2,1).c;

n1.i=b1,n2.i=b2;

int b3=fun2(n1,n2,2).i;

n1.f=c1,n2.f=c2;

float c3=fun2(n1,n2,3).f;

printf("a3=%c b3=%d c3=%.2f ",a3,b3,c3);

}

DA fun2(DA n1,DA n2,int nType)//nType=1:char類型。nType=2:int類型。nType=3:float類型。

{

DA n3;

switch(nType)

{

case 1:n3.c=n1.c+n2.c;break;

case 2:n3.i=n1.i+n2.i;break;

case 3:n3.f=n1.f+n2.f;break;

}

return n3;

}

⑼ c語言中 聲明子函數和沒有聲明子函數有什麼區別

子函數在聲明後可以先調用,後定義;避免編譯器猜數據。操作方法如下:

1、函數的聲明,函數有兩種類型,一種是有返回值的,前面用int float double char 來定義,如int f(int n);前面的int就是返回值類型。

⑽ C語言中寫子函數時候怎麼確定子函數類型

函數定義的一般形式 1.無參函數的一般形式 類型說明符 函數名() { 類型說明 語句 } 其中類型說明符和函數名稱為函數頭。 類型說明符指明了本函數的類型,函數的類型實際上是函數返回值的類型。 該類型說明符與第二章介紹的各種說明符相同。 函數名是由用戶定義的標識符,函數名後有一個空括弧,其中無參數,但括弧不可少。{} 中的內容稱為函數體。在函數體中也有類型說明, 這是對函數體內部所用到的變數的類型說明。在很多情況下都不要求無參函數有返回值, 此時函數類型符可以寫為void。 我們可以改為一個函數定義: void Hello() { printf ("Hello,world \n"); } 這里,只把main改為Hello作為函數名,其餘不變。Hello 函數是一個無參函數,當被其它函數調用時,輸出Hello world字元串。 2.有參函數的一般形式 類型說明符 函數名(形式參數表) 型式參數類型說明 { 類型說明 語句 } 有參函數比無參函數多了兩個內容,其一是形式參數表, 其二是形式參數類型說明。在形參表中給出的參數稱為形式參數, 它們可以是各種類型的變數, 各參數之間用逗號間隔。在進行函數調用時,主調函數將賦予這些形式參數實際的值。 形參既然是變數,當然必須給以類型說明。例如,定義一個函數, 用於求兩個數中的大數,可寫為: int max(a,b) int a,b; { if (a>b) return a; else return b; } 第一行說明max函數是一個整型函數,其返回的函數值是一個整數。形參為a,b。第二行說明a,b均為整型量。 a,b 的具體值是由主調函數在調用時傳送過來的。在{}中的函數體內, 除形參外沒有使用其它變數,因此只有語句而沒有變數類型說明。 上邊這種定義方法稱為「傳統格式」。 這種格式不易於編譯系統檢查,從而會引起一些非常細微而且難於跟蹤的錯誤。ANSI C 的新標准中把對形參的類型說明合並到形參表中,稱為「現代格式」。 例如max函數用現代格式可定義為: int max(int a,int b) { if(a>b) return a; else return b; } 現代格式在函數定義和函數說明(後面將要介紹)時, 給出了形式參數及其類型,在編譯時易於對它們進行查錯, 從而保證了函數說明和定義的一致性。例1.3即採用了這種現代格式。 在max函數體中的return語句是把a(或b)的值作為函數的值返回給主調函數。有返回值函數中至少應有一個return語句。 在C程序中,一個函數的定義可以放在任意位置, 既可放在主函數main之前,也可放在main之後。例如例1.3中定義了一個max 函數,其位置在main之後, 也可以把它放在main之前。 修改後的程序如下所示。 int max(int a,int b) { if(a>b)return a; else return b; } void main() { int max(int a,int b); int x,y,z; printf("input two numbers:\n"); scanf("%d%d",&x,&y); z=max(x,y); printf("maxmum=%d",z); } 現在我們可以從函數定義、 函數說明及函數調用的角度來分析整個程序,從中進一步了解函數的各種特點。程序的第1行至第5行為max函數定義。進入主函數後,因為准備調用max函數,故先對max函數進行說明(程序第8行)。函數定義和函數說明並不是一回事,在後面還要專門討論。 可以看出函數說明與函數定義中的函數頭部分相同,但是末尾要加分號。程序第12 行為調用max函數,並把x,y中的值傳送給max的形參a,b。max函數執行的 結果 (a或b)將返回給變數z。最後由主函數輸出z的值。 函數調用的一般形式前面已經說過,在程序中是通過對函數的調用來執行函數體的,其過程與其它語言的子程序調用相似。C語言中, 函數調用的一般形式為: 函數名(實際參數表) 對無參函數調用時則無實際參數表。 實際參數表中的參數可以是常數,變數或其它構造類型數據及表達式。 各實參之間用逗號分隔。'Next of Page在C語言中,可以用以下幾種方式調用函數: 1.函數表達式 函數作表達式中的一項出現在表達式中,以函數返回值參與表達式的運算。這種方式要求函數是有返回值的。例如: z=max(x,y)是一個賦值表達式,把max的返回值賦予變數z。'Next of Page 2.函數語句 函數調用的一般形式加上分號即構成函數語句。例如: printf ("%D",a);scanf ("%d",&b);都是以函數語句的方式調用函數。 3.函數實參 函數作為另一個函數調用的實際參數出現。 這種情況是把該函數的返回值作為實參進行傳送,因此要求該函數必須是有返回值的。例如: printf("%d",max(x,y)); 即是把max調用的返回值又作為printf函數的實參來使用的。在函數調用中還應該注意的一個問題是求值順序的問題。 所謂求值順序是指對實參表中各量是自左至右使用呢,還是自右至左使用。 對此, 各系統的規定不一定相同。在3.1.3節介紹printf 函數時已提 到過,這里從函數調用的角度再強調一下。 看例5.2程序。 void main() { int i=8; printf("%d\n%d\n%d\n%d\n",++i,--i,i++,i--); } 如按照從右至左的順序求值。例5.2的運行結果應為: 8 7 7 8 如對printf語句中的++i,--i,i++,i--從左至右求值,結果應為: 9 8 8 9 應特別注意的是,無論是從左至右求值, 還是自右至左求值,其輸出順序都是不變的, 即輸出順序總是和實參表中實參的順序相同。由於Turbo C現定是自右至左求值,所以結果為8,7,7,8。上述問題如還不理解,上機一試就明白了。函數的參數和函數的值 一、函數的參數 前面已經介紹過,函數的參數分為形參和實參兩種。 在本小節中,進一步介紹形參、實參的特點和兩者的關系。 形參出現在函數定義中,在整個函數體內都可以使用, 離開該函數則不能使用。實參出現在主調函數中,進入被調函數後,實參變數也不能使用。 形參和實參的功能是作數據傳送。發生函數調用時, 主調函數把實參的值傳送給被調函數的形參從而實現主調函數向被調函數的數據傳送。 函數的形參和實參具有以下特點: 1.形參變數只有在被調用時才分配內存單元,在調用結束時, 即刻釋放所分配的內存單元。因此,形參只有在函數內部有效。 函數調用結束返回主調函數後則不能再使用該形參變數。 2.實參可以是常量、變數、表達式、函數等, 無論實參是何種類型的量,在進行函數調用時,它們都必須具有確定的值, 以便把這些值傳送給形參。 因此應預先用賦值,輸入等辦法使實參獲得確定值。 3.實參和形參在數量上,類型上,順序上應嚴格一致, 否則會發生「類型不匹配」的錯誤。 4.函數調用中發生的數據傳送是單向的。 即只能把實參的值傳送給形參,而不能把形參的值反向地傳送給實參。 因此在函數調用過程中,形參的值發生改變,而實參中的值不會變化。例5.3可以說明這個問題。 void main() { int n; printf("input number\n"); scanf("%d",&n); s(n); printf("n=%d\n",n); } int s(int n) { int i; for(i=n-1;i>=1;i--) n=n+i; printf("n=%d\n",n); } 本程序中定義了一個函數s,該函數的功能是求∑ni=1i 的值。在主函數中輸入n值,並作為實參,在調用時傳送給s 函數的形參量n( 注意,本例的形參變數和實參變數的標識符都為n, 但這是兩個不同的量,各自的作用域不同)。 在主函數中用printf 語句輸出一次n值,這個n值是實參n的值。在函數s中也用printf 語句輸出了一次n值,這個n值是形參最後取得的n值0。從運行情況看,輸入n值為100。即實參n的值為100。把此值傳給函數s時,形參 n 的初值也為100,在執行函數過程中,形參n的值變為5050。 返回主函數之後,輸出實參n的值仍為100。可見實參的值不隨形參的變化而變化。