(1)素?cái)?shù)判斷函數(shù):是返回1,否則返回0

創(chuàng)新互聯(lián)專注骨干網(wǎng)絡(luò)服務(wù)器租用十余年,服務(wù)更有保障!服務(wù)器租用,成都服務(wù)器托管 成都服務(wù)器租用,成都服務(wù)器托管,骨干網(wǎng)絡(luò)帶寬,享受低延遲,高速訪問(wèn)。靈活、實(shí)現(xiàn)低成本的共享或公網(wǎng)數(shù)據(jù)中心高速帶寬的專屬高性能服務(wù)器。
int?prime(int?n){
int?i;
if(n2??!(n1)?||?n2)
return?0;
for(i=3;i*i=n;i+=2)
if(!(n%i))
return?0;
return?1;
}
(2)編寫排序函數(shù)(冒泡排序、選擇排序)
void?bubbling(int?*p,int?n){//冒泡
int?i,j,k;
for(i=0;in;i++)
for(j=1;jn;j++)
if(p[j]p[j-1])
k=p[j],p[j]=p[j-1],p[j-1]=k;
}
void?select(int?*p,int?n){//選擇
int?i,j,k;
for(n--,i=0;in;i++){
for(k=i,j=k+1;j=n;j++)
if(p[k]p[j])
k=j;
if(k-i)
j=p[k],p[k]=p[i],p[i]=j;
}
}
(3)查找函數(shù),找到返回下標(biāo),否則返回-1
int?find(int?*p,int?n,int?x){//順序
int?i;
for(i=0;in;i++)
if(p[i]==x)
return?i;
return?-1;
}
int?fihalf(int?*p,int?n,int?x){//折半,升序?yàn)槔?/p>
int?l,r,m;
l=0,r=n-1;
while(m=(l+r)1,lr??p[m]-x)
p[m]x???l=m+1?:?r=m-1;
return?p[m]==x???m?:?-1;
}
(4)插入函數(shù),升序?yàn)槔?/p>
函數(shù)是用戶與程序的接口,在定義一個(gè)函數(shù)前,首先要清楚以下三個(gè)問(wèn)題。1) 函數(shù)的功能實(shí)現(xiàn)及算法選擇。算法選擇會(huì)在后續(xù)文章詳細(xì)講解,本節(jié)重點(diǎn)關(guān)注函數(shù)的功能實(shí)現(xiàn)。一般選取能體現(xiàn)函數(shù)功能的函數(shù)名,且見名知意,如求和函數(shù)的函數(shù)名可取為 add,求最大值的函數(shù)名可取為 max,排序函數(shù)可取名為 sort 等。2) 需要用戶傳給該函數(shù)哪些參數(shù)、什么類型,即函數(shù)參數(shù)。3) 函數(shù)執(zhí)行完后返回給調(diào)用者的參數(shù)及類型,即函數(shù)返回值類型。 函教定義格式 函數(shù)定義的一般格式為: 返回類型 函數(shù)名 (類型參數(shù)1,類型參數(shù)2,…) {函數(shù)體 }也可以不含參數(shù),不含參數(shù)時(shí),參數(shù)表中可寫關(guān)鍵字 void 或省略,為規(guī)范起見,教程中對(duì)沒有參數(shù)的函數(shù),參數(shù)表中統(tǒng)一寫 void。例如: 類型 函數(shù)名 () {函數(shù)體 }等價(jià)于: 類型 函數(shù)名 (void) //建議的書寫方式 {函數(shù)體 } 如果該函數(shù)沒有返回類型,則為 void 類型。例如: void add (int x,int y) {printf ("sum=%d\n", x+y); } 除了 void 類型外,在函數(shù)體中,均需要顯式使用 return 語(yǔ)句返回對(duì)應(yīng)的表達(dá)式的值。 函教返回值 函數(shù)的值是指調(diào)用函數(shù)結(jié)束時(shí),執(zhí)行函數(shù)體所得并返回給主調(diào)函數(shù)的值。 關(guān)于函數(shù)返回值說(shuō)明如下。1) 帶返回值的函數(shù),其值一般使用 return 語(yǔ)句返回給調(diào)用者。其格式為: return 表達(dá)式;或者 return (表達(dá)式);例如: int add (int a, int b) {return (a + b); //return 后為表達(dá)式 } 函數(shù)可以含一個(gè)或多個(gè) return 語(yǔ)句,但每次調(diào)用時(shí)只能執(zhí)行其中一個(gè) return 語(yǔ)句。例如,求整數(shù)絕對(duì)值的函數(shù): int f (int n) //含多個(gè)return語(yǔ)句,但每次調(diào)用只執(zhí)行一個(gè) {if (n = 0)return n;elsereturn -n; }
int
getdata(int
a,int
b)//括號(hào)是形式參數(shù),前面int
是函數(shù)返回值類型
{
...
return
a;//返回值
}
...是實(shí)現(xiàn)的代碼。
自己看看書上的函數(shù)定義和實(shí)現(xiàn)形式很容易的。
在C語(yǔ)言中,一個(gè)標(biāo)準(zhǔn)的函數(shù)定義語(yǔ)句塊必須包含函數(shù)返回值的類型標(biāo)識(shí)符、函數(shù)名、形參類型及數(shù)量、函數(shù)體、返回值表達(dá)式。如果函數(shù)返回值類型為 void (即無(wú)返回值),則在兩個(gè)大括號(hào)之間不能寫帶有返回值表達(dá)式的 return 語(yǔ)句,否則編譯器就會(huì)報(bào)錯(cuò)。你寫的 test 函數(shù)返回值類型為 void,而你在函數(shù)定義語(yǔ)句塊內(nèi)寫下了 return 語(yǔ)句,編譯器自然會(huì)報(bào)錯(cuò)了。
你可以將這個(gè)函數(shù)修改為以下形式:
int test(int n)
{
int m = n / 2;
return m;
}
一個(gè)函數(shù)(function)是一個(gè)可以從程序其它地方調(diào)用執(zhí)行的語(yǔ)句塊。以下是函數(shù)定義格式:
type name ( argument1, argument2, ...) statement
說(shuō)明:
type 是函數(shù)返回的數(shù)據(jù)的類型
name 是函數(shù)被調(diào)用時(shí)使用的名
argument 是函數(shù)調(diào)用需要傳入的參量(可以聲明任意多個(gè)參量)。每個(gè)參量(argument)由一個(gè)數(shù)據(jù)類型后面跟一個(gè)標(biāo)識(shí)名稱組成,就像變量聲明中一樣(例如,int x)。參量?jī)H在函數(shù)范圍內(nèi)有效,可以和函數(shù)中的其它變量一樣使用, 它們使得函數(shù)在被調(diào)用時(shí)可以傳入?yún)?shù),不同的參數(shù)用逗號(hào)(comma)隔開.
statement 是函數(shù)的內(nèi)容。它可以是一句指令,也可以是一組指令組成的語(yǔ)句塊。如果是一組指令,則語(yǔ)句塊必須用花括號(hào){}括起來(lái),這也是我們最常見到情況。其實(shí)為了使程序的格式更加統(tǒng)一清晰,建議在僅有一條指令的時(shí)候也使用花括號(hào),這是一個(gè)良好的編程習(xí)慣。
示例:每一個(gè)C語(yǔ)言程序有且只有一個(gè)main函數(shù),本身main就是一個(gè)函數(shù)。結(jié)合上面的格式,自己理解一下。
int?main()
{
return?0;
}
網(wǎng)頁(yè)題目:c語(yǔ)言編寫函數(shù)方法,C語(yǔ)言怎么編寫函數(shù)
本文網(wǎng)址:http://chinadenli.net/article8/dsgssop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、定制開發(fā)、App開發(fā)、網(wǎng)站建設(shè)、商城網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)