本文目錄一覽:
用C語言編寫程序(兩個矩陣相加)
用C語言編寫程序(兩個矩陣相加)代碼如下:
/**
MatrixAddition.c
實現兩個矩陣相加
*/
#includestdio.h
const int COLS=3;
void printMatirx(int *pArray,int rows,int cols);
void printMatirx2(int (*pArray)[COLS],int rows);
int main()
{
int A[3][4]={{15,10,9,12},
{18,14,8,7},
{16,13,6,11}};
printf(“矩陣A=\n”);
printMatirx(A,3,4);
int B[3][4]={{4,3,5,2},
{0,9,6,1},
{5,7,2,6}};
printf(“矩陣B=\n”);
printMatirx(B,3,4);
int C[3][4];
int i,j;
//矩陣相加:兩個矩陣必須行數和列數一樣才能相加,
//和矩陣的每個元素分別是兩個矩陣對應的元素的和
printf(“矩陣A+矩陣B=\n”);
for(i=0;i3;i++)//控制行
{
for(j=0;j4;j++)
{
C[i][j]=A[i][j]+B[i][j];
//printf(“%3d”,C[i][j]);//輸出結果
}
// printf(“\n”);
}
int (*p)[COLS]=C;
printMatirx2(p,3);
/*結果應為:
19 13 14 14
18 23 14 8
21 20 8 17
*/
printf(“矩陣C-矩陣A=\n”);
for(i=0;i3;i++)//控制行
{
for(j=0;j4;j++)
{
printf(“%3d”,C[i][j]-A[i][j]);//輸出結果
}
printf(“\n”);
}
/*結果應為:
4 3 5 2
0 9 6 1
5 7 2 6
*/
//矩陣數乘:
int D[3][4];
printf(“矩陣D:\n”);
for(i=0;i3;i++)//控制行
{
for(j=0;j4;j++)
{
D[i][j]=1;
printf(“%d\t”, D[i][j]);//輸出結果
}
printf(“\n”);
}
int mul;
printf(“矩陣D數乘以:”);
scanf(“%d”,mul);
printf(“矩陣D數乘以%d=\n”,mul);
for(i=0;i3;i++)//控制行
{
for(j=0;j4;j++)
{
D[i][j]=D[i][j]*mul;
printf(“%d\t”, D[i][j]);//輸出結果
}
printf(“\n”);
}
return 0;
}
擴展資料:
C語言矩陣加減法函數:
void matrix_a(double **a_matrix, const double **b_matrix, const double **c_matrix,int krow, int kline, int ktrl)
////////////////////////////////////////////////////////////////////////////
// a_matrix=b_matrix+c_matrix
// krow :行數
// kline :列數
// ktrl :大於0: 加法 不大於0:減法
////////////////////////////////////////////////////////////////////////////
{
int k, k2;
for (k = 0; k krow; k++)
{
for(k2 = 0; k2 kline; k2++)
{
a_matrix[k][k2] = b_matrix[k][k2]
+ ((ktrl 0) ? c_matrix[k][k2] : -c_matrix[k][k2]);
}
}
}
參考資料:
百度百科-C語言
C語言編程兩個數求和
用數組做,高精度演算法。數組的每一個元素放一個位,如a[0]代表個位,a[1]代表十位,依此類推。
下面是演算法的實現:
c[0]=(a[0]+b[0])%10; //c[x]為結果,a[x],b[x]為兩個加數
overflow=(a[0]+b[0])/10; //overflow為進位的值
for(i=1;in;i++) //n為你兩個加數的最大位數
{
c[i]=(a[i]+b[i]+overflow)%10; //a和b的第i位相加再加上第i-1位的進位的和的個位是c第i位的值
overflow=(a[i]+b[i]+overflow)/10; //a和b的第i位相加再加上第i-1位的進位的和的十位是向高位的進位
}
當然讀數的時候要注意,由於位數太大,可以將其當成字元串讀,再按位分離。(可能還有其他辦法,不列舉)
舉個實例
987+87=?
個位相加c[0]=(a[0]+b[0])%10=(7+7)%10=4 ,進位 overflow=(a[0]+b[0])/10=1
十位相加c[1]=(a[1]+b[1]+overflow)%10= (8+8+1)%10=7 進位 overflow=(a[1]+b[1]+overflow)/10=1
百位相加c[2]=(a[2]+b[2]+overflow)%10=(9+0+1)%10=0 進位 overflow=(a[1]+b[1]+overflow)/10=1
。。。下面類推
c語言輸入兩個整數a和b如何求和?
#include stdio.h
int main()
printf(“請輸入兩個整數:”);
scanf(“%d %d”,a,b);//
sum=a+b;//三、數據處理,把a、b的和賦值給sum;
printf(“這兩個數的和是:%d\n”,sum);//
return 0;//返回;
簡介
C語言是一門面向過程的計算機編程語言,與C++、C#、Java等面向對象編程語言有所不同。C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、僅產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。C語言描述問題比彙編語言迅速、工作量小、可讀性好、易於調試、修改和移植,而代碼質量與彙編語言相當。
C語言的兩個數相加怎麼寫?
int a,b,c;
scanf(“%d%d”,a,b); //輸入a,b
c=a+b; //兩數相加給c
printf(“%d”,c); //輸出c
C語言是一門通用計算機編程語言,應用廣泛。C語言的設計目標是提供一種能以簡易的方式編譯、處理低級存儲器、產生少量的機器碼以及不需要任何運行環境支持便能運行的編程語言。
儘管C語言提供了許多低級處理的功能,但仍然保持著良好跨平台的特性,以一個標準規格寫出的C語言程序可在許多電腦平台上進行編譯,甚至包含一些嵌入式處理器(單片機或稱MCU)以及超級電腦等作業平台。
二十世紀八十年代,為了避免各開發廠商用的C語言語法產生差異,由美國國家標準局為C語言制定了一套完整的國際標準語法,稱為ANSI C,作為C語言最初的標準。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/256304.html