c語言數組相乘
『壹』 C語言編寫一個函數將兩個一維數組對應元素相乘
兩個一維數組的長度必須相同,否則無法相乘。
思路為,循環遍歷數組,並橘山鄭將對應元素相乘,結果唯旁存到第三個數組中。
以整型為例,示例代碼如下:
void array_multi(int *a, int *b, int *r, int len)//將長度為len的數組a,b對應元素相乘,結果存於r中。
{
int i;
for(i = 0; i < len; i ++)//遍歷數組。
r[i] = a[i]*b[i];//對應元素相乘圓頌,並存於r中。
}
『貳』 C語言數組里的元素怎麼加減乘除
加法:
voidAdd(char s1[],char s2[])//參數為兩個字元串數組{ int num1[M],num2[M]; int i,j; len1 = strlen (s1); len2 = strlen (s2); for (i = len1-1,j = 0; i >= 0; i--)//num1[0]保存的是低位 num1[j++]= s1[i] - '0'; for (i = len2-1,j = 0; i >= 0; i --) num2[j++] = s2[i] - '0'; for (i = 0; i < M; i ++) { num1[i] += num2[i]; if (num1[i] > 9) { num1[i] -= 10; num1[i+1] ++; } } for(i = M-1; (i >= 0)&&(num1[i] == 0); i --) ;//找到第一個不是 0的數的位置 if (i>= 0) //從高位到低位輸出每個數 for(; i >= 0; i --) printf ("%d",num1[i]); else printf ("0\n");}
減法等於加上負的數
乘法
voidMulti(char str1[],char str2[]){ int len1,len2,i,j; int a[MAX+10],b[MAX+10],c[MAX*2+10]; memset (a,0,sizeof(a)); memset (b,0,sizeof(b)); memset (c,0,sizeof(c)); len1=strlen(str1); for(j=0,i=len1-1; i>=0; i--)//把數字倒過來 a[j++]=str1[i]-'0'; len2=strlen(str2); for(j=0,i=len2-1; i>=0; i--)//倒轉第二個整數 b[j++]=str2[i]-'0'; for(i=0; i<len2; i++)//用第二個數乘以第一個數,每次一位 for(j=0;j<len1; j++) c[i+j]+= b[i]*a[j]; //先乘起來,後面統一進位for(i=0;i<MAX*2; i++)//循環統一處理進位問題 if(c[i]>=10) { c[i+1]+=c[i]/10; c[i]%=10; } for(i=MAX*2; (c[i]==0)&&(i>=0);i--);//跳過高位的0 if(i>=0) for(; i>=0; i--) printf("%d", c[i]); else printf("0"); pritnf("\n");} 除法最難 看這里吧http://wenku..com/link?url=rvqp3ApH2ujxsqTnoEnUmxc-_-y(你們竟然會布置除法! 一般都是到乘法)
『叄』 用C語言的乘法函數的方法來計算數組的積
大數乘法基本上是乘法豎式筆算的代碼化。
基本功能有3個
1.
大數的數組表示。
2.
大數乘以小數,得到大數。
3.
大數加大數,得到大數。
對於1,其實就是int數組的每個元素存儲若干位。比如每個元素保存4個十進制位。[0]存儲個十百千,[1]存儲萬、十萬、百萬、千萬,諸如此類。一個數組保存一個大數。因此需要一個額外的int變數記錄當前數組用了多少個元素(類似於字元串長度)。
對於2,「小數」指的是能用一個int保存的數。注意這里只限4個二進制位(和1里提到的位數一致)。
比如1
2345
6789這個數字,[0]保存6789,[1]保存2345,[2]保存1。長度3。
『肆』 C語言編程,用指針求所有數組元素的乘積。
C語言代碼。 #include<stdio.h> void main() { int i,a[6],*p,sum=1; for(i=0;i<6;i++) { scanf("%d",&a[i]); } for(p=a;p<a+6;p++) { sum=sum*(*p); } printf("sum=%d\n",sum); } 我求的是數組有六個元素的情況,相信聰明的你可以舉一反三。