新聞中心
C語言編寫一個(gè)函數(shù)將兩個(gè)一維數(shù)組對(duì)應(yīng)元素相乘
兩個(gè)一維數(shù)組的長度必須相同,否則無法相乘。
創(chuàng)新互聯(lián)專注骨干網(wǎng)絡(luò)服務(wù)器租用十年,服務(wù)更有保障!服務(wù)器租用,中國電信云錦天府 成都服務(wù)器租用,成都服務(wù)器托管,骨干網(wǎng)絡(luò)帶寬,享受低延遲,高速訪問。靈活、實(shí)現(xiàn)低成本的共享或公網(wǎng)數(shù)據(jù)中心高速帶寬的專屬高性能服務(wù)器。
思路為,循環(huán)遍歷數(shù)組,并將對(duì)應(yīng)元素相乘,結(jié)果存到第三個(gè)數(shù)組中。
以整型為例,示例代碼如下:
void array_multi(int *a, int *b, int *r, int len)//將長度為len的數(shù)組a,b對(duì)應(yīng)元素相乘,結(jié)果存于r中。
{
int i;
for(i = 0; i len; i ++)//遍歷數(shù)組。
r[i] = a[i]*b[i];//對(duì)應(yīng)元素相乘,并存于r中。
}
C語言里的函數(shù) 比如乘法
這個(gè)就體現(xiàn)了C的模塊化編程思想。正如你說的,main函數(shù)里寫的是c=multi(a,b);,這只是一個(gè)函數(shù)名(看到名字就知道是實(shí)現(xiàn)一個(gè)乘法),你如果去掉main函數(shù)外面的int multi(x,y){ int x,y; int z; z=x*y; return(z);},在運(yùn)行的時(shí)候肯定會(huì)報(bào)錯(cuò),因?yàn)檫@個(gè)函數(shù)沒有定義。就像我要找一個(gè)叫張三的人,首先他要存在,否則是沒人搭理我的。
‘為什么不直接用main外面這個(gè)...再加個(gè)scanf來輸入,printf來輸出,不是也能求出積嗎?’,這個(gè)是因?yàn)镃語言語法規(guī)定,程序必須從main函數(shù)開始執(zhí)行,所以要通過main函數(shù)來調(diào)用啊。樓主說的也不是不可行,不過你這么做就違背了模塊化編程思想了。這是很小的程序,大家能看得明白,如果是很大的程序的話,糾錯(cuò)都會(huì)很困難,所以盡量做到一個(gè)函數(shù)只實(shí)現(xiàn)一個(gè)功能。
‘外面的代碼和main里的代碼有什么關(guān)系嗎?’,就是調(diào)用和被調(diào)用的關(guān)系
如何用c語言函數(shù)調(diào)用編寫九九乘法表
編寫九九乘法表主要是通過循環(huán)語句進(jìn)行控制輸出乘法表中各項(xiàng)。將實(shí)現(xiàn)九九乘法表的程序單獨(dú)寫成一個(gè)函數(shù),就可以在主函數(shù)利用函數(shù)調(diào)用的形式來實(shí)現(xiàn)了。
具體實(shí)現(xiàn)方法可以參考如下程序:
#includestdio.h
void YangMultiplicationTable() // 實(shí)現(xiàn)九九乘法表的函數(shù)
{
int i=1,j=1;
for(i=1;i=9;i++) // 控制行數(shù),共9行
for(j=1;j=i;j++) // 控制列數(shù),每列的列數(shù)與行號(hào)一致
{
printf("%d*%d=%d",j,i,i*j); // 輸出九九乘法表的每一項(xiàng)
if(i!=j) printf("\t"); // 每行中相鄰兩項(xiàng)隔開
if(i==j) printf("\n"); // 每行輸出完畢后進(jìn)行換行
}
}
void main()
{
YangMultiplicationTable(); // 通過函數(shù)調(diào)用的方式實(shí)現(xiàn)九九乘法表
}
用C語言的乘法函數(shù)的方法來計(jì)算數(shù)組的積
大數(shù)乘法基本上是乘法豎式筆算的代碼化。
基本功能有3個(gè)
1. 大數(shù)的數(shù)組表示。
2. 大數(shù)乘以小數(shù),得到大數(shù)。
3. 大數(shù)加大數(shù),得到大數(shù)。
對(duì)于1,其實(shí)就是int數(shù)組的每個(gè)元素存儲(chǔ)若干位。比如每個(gè)元素保存4個(gè)十進(jìn)制位。[0]存儲(chǔ)個(gè)十百千,[1]存儲(chǔ)萬、十萬、百萬、千萬,諸如此類。一個(gè)數(shù)組保存一個(gè)大數(shù)。因此需要一個(gè)額外的int變量記錄當(dāng)前數(shù)組用了多少個(gè)元素(類似于字符串長度)。
對(duì)于2,“小數(shù)”指的是能用一個(gè)int保存的數(shù)。注意這里只限4個(gè)二進(jìn)制位(和1里提到的位數(shù)一致)。
比如1 2345 6789這個(gè)數(shù)字,[0]保存6789,[1]保存2345,[2]保存1。長度3。
這個(gè)大數(shù)乘以小數(shù),比如9999,過程就是[0] * 9999,即6789 * 9999 = 6788 3211,積的低四位(%10000)3211保存到積(大數(shù))的[0],剩下6788的進(jìn)位到[1]。
然后2345 * 9999 = 2344 7655,加上剛才進(jìn)位上來的6788得到2345 4443,其中4443保存到積(大數(shù))的[1]中,2345進(jìn)位到[2]。
以此類推。
對(duì)于3,基本只要一個(gè)for,對(duì)位相加然后注意進(jìn)位就行了。
大數(shù)乘以大數(shù),其實(shí)就是第一個(gè)大數(shù)先乘以第二個(gè)大數(shù)的[0](大數(shù)乘小數(shù),上面的2),得到一個(gè)大數(shù)A0;然后第一個(gè)大數(shù)乘以第二個(gè)大數(shù)的[1],又得到一個(gè)大數(shù)A1……最后再將A0、A1、……加起來(也就是大數(shù)加法,上面的3)。加的時(shí)候要注意,A1的[0]要和A0的[1]對(duì)齊,A2的[0]要和A1的[1]和A0的[2]對(duì)齊……這個(gè)也和我們豎式筆算一樣。
PS:上面的算法基本上是“10000進(jìn)制數(shù)”的計(jì)算方式。如果數(shù)組的每個(gè)元素只保存1個(gè)十進(jìn)制位,那就是10進(jìn)制數(shù)。之所以用10000進(jìn)制,純粹是程序員感覺上好一些。最有效的利用,是每個(gè)int保存2的15次方,也就是32768進(jìn)制。要注意到,如果用10進(jìn)制計(jì)算的話,程序的計(jì)算耗時(shí)會(huì)變成10000進(jìn)制的16倍,也就是效率變成1/16。
PS2:用int數(shù)組的話,位數(shù)最多只能是4位。因?yàn)?位數(shù)相乘可能得到11位數(shù),超出了int表示范圍。
C語言 編寫函數(shù),求兩數(shù)的乘積。
#include stdio.h
//計(jì)算兩數(shù)相乘函數(shù)
int multi(int x,int y)
{
return x*y; //返回兩數(shù)相乘結(jié)果
}
int main()
{
int m,n;
printf("輸入兩個(gè)整數(shù): ");
scanf("%d%d",m,n);
printf("%d * %d = %d\n",m,n,multi(m,n)); //調(diào)用函數(shù),輸出結(jié)果
return 0;
}
網(wǎng)站欄目:c語言里的函數(shù)和乘法 c語言乘方函數(shù)是什么
本文鏈接:http://ef60e0e.cn/article/hgsddj.html