函數(shù)調(diào)用不能這么用,第36行。C標(biāo)準(zhǔn)里面返回值是不能直接返回一個(gè)數(shù)組的,只能返回?cái)?shù)組的首地址。輸出學(xué)生成績(jī)和每科成績(jī)那個(gè)函數(shù),你可以定義一個(gè)全局變量數(shù)組,還有求平均值最好用float 或者double,用int會(huì)造成精度流失。幫你調(diào)試了一下,大概就這樣吧
創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供廣宗網(wǎng)站建設(shè)、廣宗做網(wǎng)站、廣宗網(wǎng)站設(shè)計(jì)、廣宗網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、廣宗企業(yè)網(wǎng)站模板建站服務(wù),十余年廣宗做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
通俗的說如果把二維數(shù)組看做一個(gè)表格的話,前面[3]代表行,而[5]代表列,
而一個(gè)數(shù)組的代表的最基本含義就是一個(gè)行,
那么數(shù)組指針的的話,必然是指向數(shù)組即指向行,那么說回這個(gè)題目,
int *[5]代表,該指針指向的是一個(gè)列為5個(gè)元素組成的數(shù)組,那么int a[3][5]代表的是有3行的每行有5個(gè)元素組成的數(shù)組,該指針指向的數(shù)組的存儲(chǔ)大小與這個(gè)2維數(shù)組的單行存儲(chǔ)大小匹配,自然可以指向其中的某一行
而int*[3]只有3個(gè)元素?zé)o法與5個(gè)元素相匹配,自然不能指向其中的一行
C語(yǔ)言編程的過程中,不可避免的會(huì)碰到二維或二維以上的數(shù)組作為函數(shù)的形參的情況,在以前的編程過程中,習(xí)慣了動(dòng)態(tài)數(shù)組的應(yīng)用,很是使用直接定義高維數(shù)組。最近在編程的過程中就碰到了這個(gè)問題:有如下的測(cè)試程序:
voidtest(double??**x,int?Row,int?Col);
voidtest(double??**x)
{
for(int?i=0;iRow;i++)
for(int?k=0;kCol;k++)
x[i][k]?+=?100.0;
}
intmain(int?argc,?char?*argv[])
{
/*
double?**x;
x?=?new?double?*[3];
for(int?i=0;i3;i++)
x[i]?=?new?double[3];
*/
double?x[3][3];
for(int?i=0;i3;i++)
for(int?k=0;k3;k++)
x[i][k]?=?i*k;
test(x,3,3);
for(int?i=0;i3;i++)
for(int?k=0;k3;k++)
printf("x[%d][%d]=?%e\n",i,k,x[i][k]);
getch();
return?0;
}
編譯時(shí)提示Cannot?convert?'double?[*][3]'?to?double?**'。
將調(diào)用方式強(qiáng)制進(jìn)行類型轉(zhuǎn)換:test((double?**)x),編譯通過,運(yùn)行出錯(cuò),提示非法越界。
據(jù)傳:因?yàn)闂I戏峙涞臄?shù)組和堆上分配的數(shù)組在內(nèi)存排列上可能不相同,直接定義的數(shù)組是存儲(chǔ)在程序的堆棧區(qū),數(shù)據(jù)占用連續(xù)的區(qū)間;而動(dòng)態(tài)申請(qǐng)的數(shù)組是在系統(tǒng)的遠(yuǎn)堆上(far?heap),除最后一維的元素是連續(xù)存放的外,其他維上的元素有可能不是在一塊連續(xù)的內(nèi)存區(qū)域里。
//棧上:?
int???ia[2][2]???=?{2,3,4,5};????//4個(gè)元素是連續(xù)排列的內(nèi)存段?
//堆上:?
int???**p??=??new??int*[2];???//只有每行內(nèi)是連續(xù)排列,各行并不一定連續(xù)排列?
for?(?int??i??=?0;??i???2;?i++?)?
{?
p[i]???=??new??int[2];?
}?
for?(?int??i??=??0;??i????2;??i++?)?
{?
for?(?int??j??=??0;??j????2;??j++?)?
{?
p[i][j]???=???ia[i][j];?
}?
}?
所以對(duì)棧上的數(shù)組用int??**p指向首地址,因?yàn)閕nt??**p一次解引用為地址指針,而非堆上的指向數(shù)組的指針,所以二次解引用會(huì)出錯(cuò)。?
如果找一個(gè)通用方程只能用:?
void???f(?int??*p,?int??row,??int??col?)?????//給出數(shù)組的行和列,對(duì)堆上的數(shù)組不合適???
{?
for?(?int??i?=??0;??i????row;??i++)?
{?
for?(?int??j??=??0;??j???col;??j++?)?
{?
cout???p[i?*?row?+?j]???"???";????????????????????????
}?
cout???endl;?
}?
}?
int???main(){?
//.........?
int???ia[2][2]???=??{2,3,4,5};?
f(?(int*)ia,?2,?2?);?
}
采用上面的通用辦法還是比較麻煩,這無(wú)形中對(duì)編程增加了難度,為了避免這個(gè)麻煩可以采用動(dòng)態(tài)數(shù)組的形式,將原來(lái)采用直接定義的數(shù)組全部換成動(dòng)態(tài)數(shù)組,類似開頭例子中被注釋掉的那部分代碼,當(dāng)然這樣也有后續(xù)的麻煩,動(dòng)態(tài)數(shù)組的生命周期完成后必須釋放內(nèi)存空間,這也有點(diǎn)羅嗦,但是畢竟可以直接使用數(shù)組的形式,比上面的通用方式還是要簡(jiǎn)單一點(diǎn)。
如果執(zhí)意要使用直接定義的數(shù)組該怎么辦呢?有如下幾種方法:
方法一:
voidtest(double??(*x)[3],?int?Row,?int?Col);
調(diào)用方式:test(x,Row,Col);
調(diào)用用方式?test(x,Row,Col);
方法二:
voidtest(double??x[][3],?int?Row,int?Col);
調(diào)用方式?test(x,Row,Col);
對(duì)于多維數(shù)組作為參數(shù),除第一維之外的其它維必須指定維數(shù),否則是肯定編譯不過去的。
從上面的對(duì)直接定義的數(shù)組的引用情況看,直接定義的數(shù)組的使用比較麻煩,一旦直接定義數(shù)組的維數(shù)發(fā)生變換,函數(shù)的定義必須相應(yīng)的修改,否則程序就會(huì)出錯(cuò),這也增加了程序進(jìn)一步開發(fā)的麻煩,為了一勞永逸的解決這個(gè)問題,建議還是使用動(dòng)態(tài)數(shù)組的方法,雖然需要手工釋放內(nèi)存,但是除卻了后續(xù)的麻煩。
對(duì)的,是我的第二種方法。
1.可以用指針。
void
Func(int
**array,
int
m,
int
n);
在轉(zhuǎn)變后的函數(shù)中,array[i][j]這樣的式子是不對(duì)的(不信,大家可以試一下),因?yàn)榫幾g器不能正確的為它尋址,所以我們需要模仿編譯器的行為把a(bǔ)rray[i][j]這樣的式子手工轉(zhuǎn)變?yōu)椋?/p>
*((int*)array
+
n*i
+
j);
2.可以用二維數(shù)組名作為實(shí)參或者形參,在被調(diào)用函數(shù)中對(duì)形參數(shù)組定義時(shí)可以指定所有維數(shù)的大小,也可以省略第一維的大小說明,如:
void
Func(int
array[3][10]);
void
Func(int
array[][10]);
二者都是合法而且等價(jià),但是不能把第二維或者更高維的大小省略,如下面的定義是不合法的:
void
Func(int
array[][]);
因?yàn)閺膶?shí)參傳遞來(lái)的是數(shù)組的起始地址,在內(nèi)存中按數(shù)組排列規(guī)則存放(按行存放),而并不區(qū)分行和列,如果在形參中不說明列數(shù),則系統(tǒng)無(wú)法決定應(yīng)為多少行多
少列,不能只指定一維而不指定第二維,下面寫法是錯(cuò)誤的:
void
Func(int
array[3][]);
實(shí)參數(shù)組維數(shù)可以大于形參數(shù)組,例如實(shí)參數(shù)組定義為:
void
Func(int
array[3][10]);
而形參數(shù)組定義為:
int
array[5][10];
這時(shí)形參數(shù)組只取實(shí)參數(shù)組的一部分,其余部分不起作用。
數(shù)組的4種聲明方式:
1.先聲明再初始化
例如:
//1.聲明
int[] nums;
//初始化
nums = new int[5];
2.聲明并初始化
例如:
//2.聲明、初始化
int[] nums = new int[10];
3.創(chuàng)建數(shù)組同時(shí)賦值
例如:
//3.創(chuàng)建數(shù)組同時(shí)賦值
String[] names=new String[]{"大名","小米","夏雨荷"};
int[] ages=new int[]{21,22,21,56,13};
for (int i = 0;i names.length;i++){
System.out.prinrln(names[i]);
}
for (int i = 0;i ages.length;i++){
System.out.prinrln(ages[i]);
}
4.創(chuàng)建同時(shí)賦值,簡(jiǎn)寫,不能寫成兩條語(yǔ)句
例如:
//4.創(chuàng)建同時(shí)賦值,簡(jiǎn)寫,不能寫成兩條語(yǔ)句
String[] cities = {"上海","北京"};
擴(kuò)展資料:
數(shù)組(Array)是有序的元素序列。若將有限個(gè)類型相同的變量的集合命名,那么這個(gè)名稱為數(shù)組名。組成數(shù)組的各個(gè)變量稱為數(shù)組的分量,也稱為數(shù)組的元素,有時(shí)也稱為下標(biāo)變量。用于區(qū)分?jǐn)?shù)組的各個(gè)元素的數(shù)字編號(hào)稱為下標(biāo)。數(shù)組是在程序設(shè)計(jì)中,為了處理方便, 把具有相同類型的若干元素按有序的形式組織起來(lái)的一種形式。 這些有序排列的同類數(shù)據(jù)元素的集合稱為數(shù)組。
數(shù)組是用于儲(chǔ)存多個(gè)相同類型數(shù)據(jù)的集合。
在C語(yǔ)言中, 數(shù)組屬于構(gòu)造數(shù)據(jù)類型。一個(gè)數(shù)組可以分解為多個(gè)數(shù)組元素,這些數(shù)組元素可以是基本數(shù)據(jù)類型或是構(gòu)造類型。因此按數(shù)組元素的類型不同,數(shù)組又可分為數(shù)值數(shù)組、字符數(shù)組、指針數(shù)組、結(jié)構(gòu)數(shù)組等各種類別。
不可能達(dá)到目的。因?yàn)镃語(yǔ)言中沒有引用這類型,C++才有。另,C/C++都不支持傳遞數(shù)組,只能傳遞數(shù)組的首元素或行指針,所以即使是C++,也只能傳遞數(shù)組指針的引用,而不可能傳遞數(shù)組的引用,因?yàn)閿?shù)組沒有引用。