本文目录一览:
- 1、求通过C语言实现矩阵的加、减及乘法。要自己写的,不要复制过来
- 2、用c语言编写矩阵的加减乘除运算
- 3、C语言实现的矩阵加减乘法
- 4、!!!跪求C语言实现矩阵运算(加,减,乘、求逆、转置)
- 5、用c语言计算矩阵加法和乘法
求通过C语言实现矩阵的加、减及乘法。要自己写的,不要复制过来
#include iostream
using namespace std;
int main()
{
int am=3,bm=3,an=3,bn=3;
int a[am][an];
int b[bm][bn];
for(int i=0;iam;i++)
{
for(int j=0;jan;j++)
{
a[i][j]=i*am+j;
}
}
for(int i=0;ibm;i++)
{
for(int j=0;jbn;j++)
{
b[i][j]=i*bm+j;
}
}
//original matrix
cout"原始矩阵a"endl;
for(int i=0;iam;i++)
{
for(int j=0;jan;j++)
{
couta[i][j]" ";
if(j==an-1)
coutendl;
}
}
cout"原始矩阵b"endl;
for(int i=0;ibm;i++)
{
for(int j=0;jbn;j++)
{
coutb[i][j]" ";
if(j==bn-1)
coutendl;
}
}
//matrix add
cout"矩阵加法"endl;
if(am!=bm || an!=bn)
{
cout"Sorry, can not be added!"endl;
}
else for(int i=0;iam;i++)
{
for(int j=0;jan;j++)
{
couta[i][j]+b[i][j]" ";
if(j==an-1)
coutendl;
}
}
//matrix minus
cout"矩阵减法"endl;
if(am!=bm || an!=bn)
{
cout"Sorry, can not be minused!"endl;
}
else for(int i=0;iam;i++)
{
for(int j=0;jan;j++)
{
couta[i][j]-b[i][j]" ";
if(j==an-1)
coutendl;
}
}
//matrix multiply
cout"矩阵乘法"endl;
int temp;
if(an!=bm)
{
cout"Sorry, can not be multiplied!"endl;
}
else for(int i=0;iam;i++)
{
for(int j=0;jbn;j++)
{
temp=0;
for(int k=0;kan;k++)
{
temp+=a[i][k]*b[j][k];
}
couttemp" ";
if(j==bn-1)
coutendl;
}
}
}
用c语言编写矩阵的加减乘除运算
#include iostream
#include iomanip
using namespace std;
template typename T1,typename T2
void inverse(T1*mat1,T2 *mat2,int a,int b);
template typename T1,typename T2
void multi(T1*mat1,T2*mat2,T2*result,int a,int b,int c);
template typename T
void output(T*mat,char *s,int a,int b);
int main(){
int middle[6][3],result[6][4];
int matrix1[3][6]={8,10,12,23,1,3,5,7,9,2,4,6,34,45,56,2,4,6};
int matrix2[3][4]={3,2,1,0,-1,-2,9,8,7,6,5,4};
char*s1="result";
char*s2="middle";
//inverse(matrix1,middle,6,3);
inverseint[6],int[3](matrix1,middle,6,3);
//multi(middle,matrix2,result,6,3,4);
multiint[3],int[4](middle,matrix2,result,6,3,4);
output(matrix1,"matrix1",3,6);
output(middle,s2,6,3);
output(matrix2,"matrix2",3,4);
output(result,s1,6,4);
return 0;
}
template typename T1,typename T2
void inverse(T1*mat1,T2*mat2,int a,int b){
int i,j;
for(i=0;ib;i++)
for(j=0;ja;j++)
mat2[j][i]=mat1[i][j];
return;
}
template typename T1,typename T2
void multi(T1*mat1,T2*mat2,T2*result,int a,int b,int c){
int i,j,k;
for(i=0;ia;i++){
for(j=0;jc;j++){
result[i][j]=0;
for(k=0;kb;k++)
result[i][j]+=mat1[i][k]*mat2[k][j];
}
}
return;
}
templatetypename T
void output(T*mat,char*s,int a,int b){
int i,j;
coutsendl;
for(i=0;ia;i++){
for(j=0;jb;j++)
coutsetw(6)mat[i][j];
coutendl;
}
return;
}
C语言实现的矩阵加减乘法
#includestdio.h
/*
m1和m2为两个相加的数组首元素地址,r和c为两个数组的行数和列数
m用于存放结果。
调用该函数时,要求m为有足够存储单元、能容纳运算结果的数组首元素地址
*/
void add(int *m,int *m1,int *m2,int r,int c);
void sub(int *m,int *m1,int *m2,int r,int c);
void mult(int *m,int *m1,int *m2,int r,int p,int c);
void disp(int *m,int r,int c);
void main()
{
int a[3][4]={{2,4,6,8},{1,3,5,7},{11,33,44,22}};
int b[3][4]={{2,-4,6,-8},{-1,3,-5,7},{11,-33,-44,22}};
int c[4][3]={{2,4,6},{1,3,5},{1,0,3},{0,2,4}};
int d[3][4]={0};
int e[3][3]={0};
printf("\nA(3x4):\n");
disp(a[0],3,4);
printf("\nB(3x4):\n");
disp(b[0],3,4);
add(d[0],a[0],b[0],3,4);
printf("\nD(3x4)=A+B:\n");
disp(d[0],3,4);
sub(d[0],a[0],b[0],3,4);
printf("\nD(3x4)=A-B:\n");
disp(d[0],3,4);
printf("\nA(3x4):\n");
disp(a[0],3,4);
printf("\nC(4x3):\n");
disp(c[0],4,3);
mult(e[0],a[0],c[0],3,4,3);
printf("\nE(3x3)=A*C:\n");
disp(e[0],3,3);
}
void add(int *m,int *m1,int *m2,int r,int c){
int i,j;
for(i=0; ir; i++)
for(j=0; jc; j++)
*(m+i*c+j) = *(m1+i*c+j) + *(m2+i*c+j);
}
void sub(int *m,int *m1,int *m2,int r,int c){
int i,j;
for(i=0; ir; i++)
for(j=0; jc; j++)
*(m+i*c+j) = *(m1+i*c+j) - *(m2+i*c+j);
}
void mult(int *m,int *m1,int *m2,int r,int p,int c){
int i,j,k,t;
for(i=0; ir; i++)
for(j=0; jc; j++)
{
t=0;
for(k=0; kp; k++)
t += *(m1+i*p+k) * *(m2+k*c+j);
*(m+i*c+j)=t;
}
}
void disp(int *m,int r,int c)
{
int i,j;
for(i=0; ir; i++)
{
for(j=0; jc; j++)
printf("%6d",*(m+i*c+j));
printf("\n");
}
}
!!!跪求C语言实现矩阵运算(加,减,乘、求逆、转置)
1、首先打开vs2015(其他版本也可以),新建一个Windows Form窗体程序或者控制台都可以。
2、 定义一个名为array1的数组并赋值:double[,] array1 = new double[3, 3] { { 1, 2, 3 }, { 4, 5, 6 }, { 7, 8, 9 } };下面求该矩阵转置矩阵。
3、接下来实现矩阵的转置运算,可以写函数也可以写类,右键解决方案下的项目名,添加-类。
4、创建一个名为“turnzhi”的类(名字随便取,最好用英文,有时候中文名程序会报错),然后点击“添加”。
5、转置类的代码如下图所示。
6、在主程序调用转置类,用两个for循坏将转置后的数组(array)输出来;并将结果显示在textbox中。
7、最后运行程序查看编写的结果:147、258、369。转置后的结果正确,这样就实现了c#矩阵的转置运算。
用c语言计算矩阵加法和乘法
指向结构变量的指针
#include "stdio.h"
#include "math.h"
int main(void)
{
double n;
scanf("%lf", n);
printf("%lf", pow(n, 2));
return 0;
}
直接用pow函数!