『壹』 關於c語言的二維數組作為函數參數的問題
所謂二維數組,實際上是指向數組的指針,比如:
int n=2,m=3;
int arr[n][m];
實際上相當於:
int n=2,m=3;
int (*arr)[m];
所以,傳遞二維數組作為參數,實際上就是傳遞了一個指針。
將形參的類型定義成int*,再在函數內部轉換回指向數組的指針就行了,比如:
void f(int *p,int row,int column)
{
int (*arr)[column]=(int (*)[column])p;
//使用二維數組arr
}
這樣傳遞參數:
int n=5,m=6;
int arr[n][m];
f((int*)arr,n,m);
下面是一個例子:
#include <stdio.h>
void f(int *p,int row,int column)
{
int (*arr)[column]=(int (*)[column])p;
for(int i=0;i<row;i++)
{
for(int j=0;j<column-1;j++)
printf("%d,",arr[i][j]);
printf("%d ",arr[i][column-1]);
}
}
int main()
{
int n;
scanf("%d",&n);
int arr[n][n];
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
arr[i][j]=i*n+j;
}
f((int*)arr,n,n);
return 0;
}
這是運行截圖:
『貳』 C語言中如何將二維數組作為函數的參數傳遞
函數原型 type fun (type (name*)[size])
type是你要定義的類型,fun是函數名,name是在函數中二維數組的名字,
size是二維數組第2維的長度。
這樣調用這個函數只需要把二維數組函數名傳遞就可以了。
『叄』 「c語言」和「c++語言」如何用二維數組做形參
二維數組做形參?C++的數組用形參的時候非常之弱,你確定你需要它?
N維數組做形參必須指定後n-1維的大小,不然編譯器無法知道如何使用它,
如
void func(int a[][10]) 或 void func2(int b[][10][10])
雖然寫是可以這樣子寫,不過,其實上面那種代碼等價於
void func(int (*a)[10]) 和 void func2(int (*b)[10][10])
『肆』 c語言c++語言如何用二維數組做形參
C/C++中,二維數組的第一維的每一個元素都是一維數組。所以,用指向一維數組的指針或用第一維維數空缺的二維數組作為函數的形式參數都能達到目的。設處理數組為int型,舉例代碼如下:
//#include"stdafx.h"//Ifthevc++6.0,withthisline.
#include"stdio.h"
voidmyprint(int(*p)[5]){//p是指向有5個int型元素的一維數組的指針
//voidmyprint(intp[][5]){//這樣寫效果是一樣的
inti,j;
for(i=0;i<3;i++){
for(j=0;j<5;printf("%3d",p[i][j++]));
printf(" ");
}
}
intmain(void){
inta[3][5]={{1,2,3,4,5},{6,7,8,9,10},{11,12,13,14,15}};
myprint(a);
return0;
}
『伍』 c語言如何定義二維數組
二維數組定義的一般形式是:
dataType arrayName[length1][length2];
其中,dataType 為數據類型,arrayName 為數組名,length1 為第一維下標的長度,length2 為第二維下標的長度。
例如:
int a[3][4];
定義了一個 3 行 4 列的二維數組,共有 3×4=12 個元素,數組名為 a,即:
a[0][0], a[0][1], a[0][2], a[0][3]
a[1][0], a[1][1], a[1][2], a[1][3]
a[2][0], a[2][1], a[2][2], a[2][3]
『陸』 c語言二維數組做參數形參該怎麼寫,舉個例子
例如下面這個
int fun(int a[2][3],int n);
或者
int fun(int a[][3],int n);
要指出列數是多少,行數寫不寫都一樣,行數要通過n進行傳遞。
假設
int b[2][3]={};
則調用的時候可以寫
fun(b,2);
『柒』 C語言中如何將二維數組作為函數的參數傳遞
在c語言中可以用二維數組作為實參或者形參。
1、函數中用二維數組作為形參,函數聲明中可以指定所有維數的大小,也可以省略第1維的維數如:
void f(int array[3][10]); //正確
void f(int array[][10]); //正確上面的兩種二維數組形參表示都是正確的。
2、函數中用二維數組作為形參,不能把第2維或者更高維的大小省略,如下面的定義是不合法的:
void f(int array[][]); //錯誤
因為從實參傳遞來的是數組的起始地址,在內存中按數組排列規則存放(按行存放),而並不區分行和列,如果在形參中不說明列數,則系統無法決定應為多少行多少列,不能只指定一維而不指定第二維,下面寫法是錯誤的:
void f(int array[3][]); //錯誤 3、二維數組作為實參傳遞時,必須保證實參第2維的維數與形參第2維的維數相同,因為必須要保證形參和實參的數據類型一致。比如定義如下函數:
void f(int array[][10]);可以將如下數組傳遞給函數f。
int a[2][10] = {1,2,3,4};
int b[4][10] = {1};
『捌』 C語言怎麼以二維數組作為參數傳遞的問題
考慮要把a作為參數傳入到print中,那麼print函數就要定義一個接收二維數組的參數,那麼什麼參數能接收二維數組呢。
就是print(int (*newbuf)[3])
然後newbuf的地址就是a的地址,然後newbuf[i][j]來訪問每一個元素了
有問題繼續問哈,寫的可能不太明白
『玖』 c語言中怎麼用二維數組作為函數參數
二維數組作為函數參數,實參可以直接使用二維數組名,在被調用函數中對形參數組定義可以指定所有維數的大小,也可以省略第一維的大小說明,如:
因為從實參傳遞來的是數組的起始地址,如果在形參中不說明列數,編譯器將無法定位元素的的位置。