c語言數組指針做函數參數,c語言中數組做函數參數

本文目錄一覽:

請問在C語言中,函數傳參時怎樣利用指針傳遞數組

數組名就是指針,例如:

#include stdio.h

void pr(char *p)

{

printf(p);

}

void main(void)

{

char s[] = “abc”;

pr(s);

}

擴展資料:

注意事項

非數組類的聲明盡量以指針的方式進行比較好。倘若一個指針指向的內存並不是一個數組,那麼採用數組名的聲明方式或許就會給人產生錯誤的引導。類似的,如果指向的是一個數組區域,則會給人以更加豐富的信息。例如:

int main(int argc,char* argv[])

{

/* code here */

}

int main(int argc,char** argv)

{

/* code here */

}

兩種方式完全等價,但是前面一種能夠更清晰地看出:這個參數是指向某個元素起始地址的指針,而後面的這種方式則不能夠直觀地看出這種含義。

C語言中 指針做函數參數傳遞二維數組

#include stdio.h

void fun(int (*p1)[3],int (*p2)[3]);

int main()

{

int p1[3][3]={{7,8,9},{4,5,6},{1,2,3}} ;

int p2[3][3] = {0};

int i = 0, j = 0;

fun(p1,p2);

for(i = 0;i 3;i++){

for(j = 0;j 3;j++){

printf(“%d “,*(*(p2+i)+j)); 

}

printf(“\n”);

}     

return 0;

}

void fun(int (*p1)[3],int (*p2)[3])

{

int i = 0,j = 0;

for(i = 0;i 3;i++){

for(j = 0;j 3;j++){

*(p2[j]+i) = *(p1[i]+j);

}

}

}

擴展資料:

函數指針的聲明方法為:

返回值類型 ( * 指針變量名) ([形參列表]);

其中,「返回值類型」說明函數的返回類型,「(指針變量名 )」中的括號不能省,括號改變了運算符的優先級。若省略整體則成為一個函數說明,說明了一個返回的數據類型是指針的函數,後面的「形參列表」表示指針變量指向的函數所帶的參數列表。例如:

int func(int x); /* 聲明一個函數 */

int (*f) (int x); /* 聲明一個函數指針 */

f=func; /* 將func函數的首地址賦給指針f */

或者使用下面的方法將函數地址賦給函數指針:

f = func;

賦值時函數func不帶括號,也不帶參數,由於func代表函數的首地址,因此經過賦值以後,指針f就指向函數func(x)的代碼的首地址。

參考資料:

百度百科-函數指針

C語言使用數組指針參數傳遞

用指針傳遞一維數組。

#include stdio.h

#include math.h

float dist( float *p1, float *p2){

float d[3],ds;

int i;

for (i=0;i3;i++) d[i] = p2[i]-p1[i];

ds = sqrt( d[0]*d[0]+ d[1]*d[1]+d[2]*d[2]);

return ds;

};

void vec( float *p1, float *p2, float *p3){

int i;

for (i=0;i3;i++) p3[i]=p1[i]+p2[i];

}

int main()

{

float a[3],b[3],c[3];

int i;

printf(“input x y z for point 1\n”);

for (i=0;i3;i++)scanf(“%f”,a[i]);

printf(“input x y z for point 2\n”);

for (i=0;i3;i++)scanf(“%f”,b[i]);

printf(“distence: %g\n”, dist(a,b));

printf(“\n”);

vec(a,b,c);

for (i=0;i3;i++) printf(“%g “,c[i]);

return 0;

}

C語言,使用指針作為函數參數,寫一求數組中最大值和最小指的函數

#include<stdio.h>

voidhanshu(int*arry,intsize,int*m,int*n)

*m=arry[0];

*n=arry[1];

for(inti=0;i<size;i++)

if(arry[i]>*m)

*m=arry[i];

if(arry[i]<*n)

*n=arry[i];

intmain(intargc,constchar*argv[]){。

inta[]={1,5,6,2,3,8,9,7,4,5};//定義一個十個數據的數組

intmax;//存放最大值

intmin;//存放最小值

hanshu(a,10,&max,&min);//函數傳送數組,並將最大值,最小值的地址傳送

printf("Themaxnumberis%d\n",max);

printf("Theminnumberis%d\n",min);

return0;

擴展資料:

include用法:

#include命令預處理命令的一種,預處理命令可以將別的源代碼內容插入到所指定的位置;可以標識出只有在特定條件下才會被編譯的某一段程序代碼;可以定義類似標識符功能的宏,在編譯時,預處理器會用別的文本取代該宏。

插入頭文件的內容

#include命令告訴預處理器將指定頭文件的內容插入到預處理器命令的相應位置。有兩種方式可以指定插入頭文件:

1、#includelt;文件名gt;

2、#include”文件名”

C語言中,數組做函數參數如何才能按值傳遞?

傳數組給一個函數,數組類型自動轉換為指針類型,因而傳的實際是地址。

void func(int array[10])

void func(int array[])

void func(int *array)

所以以上三種函數聲明完全等同。

實際情況是,數組做參數,完全無法按值傳遞。這是由C/C++函數的實現機制決定的。

下一個問題是:為什麼偏要按值傳遞呢?當要在一個函數內使用一個數組時,傳一個指針進去不就行了?只要能訪問到我們所要的數據並對其進行操作,何苦鑽牛角尖。

c語言中數組名作為函數參數

要將數組長度作為一個參數傳給average函數,不能在average函數內部通過int arrLen = sizeof(a) / 4;來計算數組長度。因為float average(float a[10])就相當於float average(float *a) ,所以sizeof(a)恆等於4,sizeof(a) / 4恆等於1。

應該這樣:

float average(float a[10],int arrLen) {

float sumSco = 0;

for (int i = 0; i arrLen; i++)

{

sumSco += a[i];

}

return sumSco / arrLen;

}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/257878.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-15 12:47
下一篇 2024-12-15 12:47

相關推薦

  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python中capitalize函數的使用

    在Python的字符串操作中,capitalize函數常常被用到,這個函數可以使字符串中的第一個單詞首字母大寫,其餘字母小寫。在本文中,我們將從以下幾個方面對capitalize函…

    編程 2025-04-29
  • Python中set函數的作用

    Python中set函數是一個有用的數據類型,可以被用於許多編程場景中。在這篇文章中,我們將學習Python中set函數的多個方面,從而深入了解這個函數在Python中的用途。 一…

    編程 2025-04-29
  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • 三星內存條參數用法介紹

    本文將詳細解釋三星內存條上面的各種參數,讓你更好地了解內存條並選擇適合自己的一款。 一、容量大小 容量大小是內存條最基本的參數,一般以GB為單位表示,常見的有2GB、4GB、8GB…

    編程 2025-04-29
  • 單片機打印函數

    單片機打印是指通過串口或並口將一些數據打印到終端設備上。在單片機應用中,打印非常重要。正確的打印數據可以讓我們知道單片機運行的狀態,方便我們進行調試;錯誤的打印數據可以幫助我們快速…

    編程 2025-04-29
  • 三角函數用英語怎麼說

    三角函數,即三角比函數,是指在一個銳角三角形中某一角的對邊、鄰邊之比。在數學中,三角函數包括正弦、餘弦、正切等,它們在數學、物理、工程和計算機等領域都得到了廣泛的應用。 一、正弦函…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • Python3定義函數參數類型

    Python是一門動態類型語言,不需要在定義變量時顯示的指定變量類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

    編程 2025-04-29

發表回復

登錄後才能評論