当前位置:首页 » 编程语言 » c语言矩阵运算
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言矩阵运算

发布时间: 2022-02-01 20:31:51

⑴ 用c语言实现两个矩阵相乘怎么做

1、程序运行输入数据时,第一行为A矩阵的行列数和B矩阵的行列数,接着分别输入A、B两个矩阵的值。

⑵ c语言矩阵运算问题 紧急

#include<stdio.h>
#include<stdlib.h>

typedef struct Matrix{
int *m;
int col;
int row;
};

Matrix* ConsMatrix(int *a,int cn,int rn){
Matrix *ma=(Matrix*)malloc(sizeof(Matrix));
ma->m=a;
ma->col=cn;
ma->row=rn;
return ma;
}

void PrintMatrix(Matrix *ma){
int i,j;
for(i=0;i<ma->row;i++){
for(j=0;j<ma->col;j++){
printf("%d ",ma->m[i*(ma->col)+j]);
}
printf("\n");
}
}

Matrix* MatrixSub(Matrix*ma,Matrix*mb){
Matrix *mc=(Matrix*)malloc(sizeof(Matrix));

if(ma->col==mb->col&&ma->row==mb->row){

int size=ma->row*ma->col;
int i;
int *d=(int*)malloc(sizeof(int)*size);
mc->m=d;
mc->row=ma->row;
mc->col=ma->col;
for(i=0;i<size;i++){
mc->m[i]=ma->m[i]-mb->m[i];
}
return mc;
}
printf("row or col cant match");
return NULL;
}

int main(){
int a[6]={1,2,3,4,5,6};
int b[6]={2,3,4,5,6,7};
Matrix *mb=ConsMatrix(b,2,3);
Matrix *ma=ConsMatrix(a,2,3);
Matrix *mc=MatrixSub(mb,ma);
PrintMatrix(mc);
system("pause");
return 1;
}

⑶ 这个C语言矩阵乘法错在哪里

错误比较多呢。我都注释出来了。重复的代码提出来写成了单独的函数,仅这样就可以避免不少错误。最关键的是矩阵乘法的下标范围搞错了,有一个for后面直接跟了分号。

所以要多注意细节,再细心些。

#include<stdio.h>
#defineN100
voidread(inta[][N],inth,inti){
intm,n;
for(m=0;m<h;m++){
for(n=0;n<i;n++){
scanf_s("%d",&a[m][n]);
}
}
}

voidprint(inta[][N],inth,inti){
intm,n;
for(m=0;m<h;m++){
for(n=0;n<i;n++){
printf("%4d",a[m][n]);
}
printf(" ");
}
}

voidmultiply(inta[][N],intb[][N],intc[][N],inth,inti,intk){
intm,n,x;
for(m=0;m<h;m++){//**这三重循环的条件要分清楚:h,k,i
for(n=0;n<k;n++){
c[m][n]=0;//**前面已经清零了,这里可以不写
for(x=0;x<i;x++){//**这里,原来for后面是分号!!;
c[m][n]+=a[m][x]*b[x][n];
}
}
}
}

intmain(){
inth,i,j,k,a[N][N],b[N][N],c[N][N]={0};//**不需要d,c要初始化,清零
while(1){//计算完一次后循环到下次计算
printf("请分别输入两个矩阵的行列数,以空格隔开: ");
scanf_s("%d%d%d%d",&h,&i,&j,&k);//得到矩阵1、2的行列数为h、i和j、k
if(i!=j){
printf("这两个矩阵不能相乘。 ");
continue;//**不需要goto
}
printf("请输入矩阵1的所有元素,以空格隔开: ");
read(a,h,i);
printf("矩阵1为: ");//输出矩阵1,方便查看
print(a,h,i);
printf("请输入矩阵2的所有元素,以空格隔开: ");
read(b,j,k);
printf("矩阵2为: ");//输出矩阵2,方便查看
print(b,j,k);
multiply(a,b,c,h,i,k);
printf("两矩阵的积是: ");//输出矩阵3
print(c,h,k);
printf("运算完成。 ");
}
}

⑷ C语言矩阵运算问题

FIN[3][3] = A[i][j] x B[i][j];改为FIN[i][j] = A[i][j]*B[i][j];
因为FIN[3][3]不是矩阵FIN的坐标,而且这个坐标不应该是固定值,应该是变化的
乘法的符号是*不是x。
望采纳。。。。。。

⑸ c语言矩阵乘法

main()
{
int i=0,j=0,k=0,n=0,m=0;/*k
为待输入值
*/
int s=0;/*
此处作为输出变量
*/
int middle=0; /*
中间值
*/
int a[row][line],b[line][row];
long c[row][row];
for(i=0;i<row;i++)
{
for(j=0;j<line;j++)
{
scanf("%d",&k);
a[i][j]=k;
printf("\ta[%d][%d]=%d\n",i,j,a[i][j]);
}
}
printf("\n");
for(i=0;i<line;i++)
{
for(j=0;j<row;j++)
{
scanf("%d",&k);
b[i][j]=k;
printf("\tb[%d][%d]=%d\n",i,j,b[i][j]);
}
}

⑹ c语言矩阵计算.急!

楼上的回答有问题,运行的时候不输入运算符就直接打印"没有注册这个运算符号"了,并且运算结果也没有打印出来.我做了下修改.下面是程序:
#include<stdio.h>
void add(int a[][2],int b[][2],int c[][2])
{
int i,j;
for(i=0;i<2;i++)
{for(j=0;j<2;j++)
{c[i][j]=a[i][j]+b[i][j];
printf("%d\t",c[i][j]); }
printf("\n");}
}
void minus(int a[][2],int b[][2],int c[][2])
{
int i,j;
for(i=0;i<2;i++)
{for(j=0;j<2;j++)
{c[i][j]=a[i][j]-b[i][j];
printf("%d\t",c[i][j]); }
printf("\n");}
}
void multiplication(int a[][2],int b[][2],int c[][2])
{
int i,j;
for(i=0;i<2;i++)
{for(j=0;j<2;j++)
{c[i][j]=a[i][j]*b[i][j];
printf("%d\t",c[i][j]); }
printf("\n");}
}

main()
{
int a[2][2],b[2][2],c[2][2],i,j;
char p;
puts("input 2*2 array--A:\n");
for(i=0;i<2;i++)
for(j=0;j<2;j++)
scanf("%d",&a[i][j]);
puts("input 2*2 array--B:\n");
for(i=0;i<2;i++)
for(j=0;j<2;j++)
scanf("%d",&b[i][j]);
puts("input operation:\n");
getchar();
p=getchar();
//scanf("%c",&p);
if(p=='+') add(a,b,c);else
if(p=='-') minus(a,b,c);else
if(p=='*') multiplication(a,b,c);else
puts("没有注册这个运算符号\n");
}

运行结果已经通过VC++6.0,并且结果正确.

⑺ C语言矩阵计算问题 做好的发到QQ邮箱里[email protected] 要快啊

blas lapack自己去找

⑻ 关于C语言矩阵的运算有题目要求<急>在线等答案

我自己写了一个,不过觉得输入有点麻烦,但功能上还算符合
你的要求,将就点用呵。。。。呵呵

#include<stdio.h>
#include<math.h>

void jiafa()
{
int m,n;
float a[20][20],b[20][20],c[20][20];
int i,j;

printf("请输入矩阵行数:");
scanf("%d",&m);
printf("请输入矩阵列数:");
scanf("%d",&n);

printf("请输入第一个矩阵:");
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%f",&a[i][j]);

printf("请输入第二个矩阵:");
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%f",&b[i][j]);

printf("矩阵相加的结果为:");
for(i=0;i<m;i++)
{ for(j=0;j<n;j++)
{
c[i][j]=a[i][j]+b[i][j];
printf("%4f ",c[i][j]);
}
printf("\n");
}
}

void jianfa()
{
int m,n;
float a[20][20],b[20][20],c[20][20];
int i,j;

printf("请输入矩阵行数:");
scanf("%d",&m);
printf("请输入矩阵列数:");
scanf("%d",&n);

printf("请输入第一个矩阵:");
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%f",&a[i][j]);

printf("请输入第二个矩阵:");
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%f",&b[i][j]);

printf("矩阵相减的结果为:");
for(i=0;i<m;i++)
{ for(j=0;j<n;j++)
{
c[i][j]=a[i][j]-b[i][j];
printf("%4f ",c[i][j]);
}
printf("\n");
}
}

void chengfa()
{
int m,n;
float s;
float a[20][20],b[20][20],c[20][20];
int i,j,k;

printf("请输入矩阵行数:");
scanf("%d",&m);
printf("请输入矩阵列数:");
scanf("%d",&n);

printf("请输入第一个矩阵:");
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%f",&a[i][j]);

printf("请输入第二个矩阵:");
for(i=0;i<n;i++)
for(j=0;j<m;j++)
scanf("%4f",&b[i][j]);

for(i=0;i<m;i++)
{
for(j=0;j<m;j++)
{
s=0;
for(k=0;k<n;k++)
{
s=s+a[i][k]*b[k][j];
c[i][j]=s;
}
}
}
for(i=0;i<m;i++)
{
for(j=0;j<m;j++)
{
printf("%4f ",c[i][j]);
}
printf("\n");
}
}

void zhuan()
{
int m,n;
float a[20][20],b[20][20];
int i,j;

printf("请输入矩阵行数:");
scanf("%d",&m);
printf("请输入矩阵列数:");
scanf("%d",&n);

printf("请输入一个矩阵:");
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%f",&a[i][j]);

for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
b[i][j]=a[j][i];
printf("%4f ",b[i][j]);
}
printf("\n");
}
}

void qiuni()
{
int N;
printf("输入矩阵的阶数N:\n");
scanf("%d",&N);
float a[10][10],b[10][20],c[10][10],t;
int i,j,m;
printf("请输入行列式不为0的矩阵A(%d阶):\n",N); //矩阵A的各元素存入二维数组a中。
for(i=0;i<N;i++)
for(j=0;j<N;j++)
scanf("%f",&a[i][j]);
//增广矩阵(A|E)存入二维数组b中
for(i=0;i<N;i++)
for(j=0;j<N;j++)
b[i][j]=a[i][j];

for(i=0;i<N;i++)
for(j=N;j<2*N;j++)
b[i][j]=0;

for(i=0;i<N;i++)
b[i][N+i]=1;

for(m=0;m<N;m++) //对每行进行处理。
{
t=b[m][m]; //预存b[m][m]。
i=m;
while(b[m][m]==0)
{
b[m][m]=b[i+1][m];
i++;
}

if(i>m)
{
b[i][m]=t; //实现交换。

//交换其它各列相应位置的元素
for(j=0;j<m;j++)
{
t=b[m][j];
b[m][j]=b[i][j];
b[i][j]=t;
}
for(j=m+1;j<2*N;j++)
{
t=b[m][j];
b[m][j]=b[i][j];
b[i][j]=t;
}

}

for(i=m+1;i<N;i++)
for(j=2*N-1;j>=m;j--)
b[i][j]-=b[i][m]*b[m][j]/b[m][m]; //m=0时,将第一行的-b[i][0]/b[0][0]倍加到以下各行。这样以下每行第一个元素b[i][0]就为0。

for(j=2*N-1;j>=m;j--)
b[m][j]/=b[m][m]; //对第m行作行变换,同除以b[m][m],使b[m][m]为1。

}

printf("第一步变换后得到的增广矩阵为:\n");
for(i=0;i<N;i++)
{
for(j=0;j<2*N;j++)
printf("%3.5f ",b[i][j]);
printf("\n"); //实现了:每个i对应一个换行。
}

m=N-1;
while(m>0)
{
for(i=0;i<m;i++)
for(j=2*N-1;j>=m;j--) //千万注意,此处j必须递减,否则b[i][m]先变为0,后面的计算就无效!
b[i][j]-=b[i][m]*b[m][j];
m--;
}

printf("最后得到的增广矩阵为:\n");
for(i=0;i<N;i++)
{
for(j=0;j<2*N;j++)
printf("%3.5f ",b[i][j]);
printf("\n"); //实现了:每个i对应一个换行。
}

for(i=0;i<N;i++) //将逆矩阵存入二维数组c中。
for(j=0;j<N;j++)
c[i][j]=b[i][N+j];

printf("故逆矩阵为:\n");

for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
printf("%3.5f ",c[i][j]);
printf("\n"); //实现了:每个i对应一个换行。
}

}

main()
{
int w;
printf("1矩阵加法\n");
printf("2矩阵减法\n");
printf("3矩阵乘法\n");
printf("4矩阵转置\n");
printf("5矩阵求逆\n");
printf("\n");
printf("请选择要进行的运算:");
scanf("%d",&w);

switch(w)
{
case 1:jiafa();break;
case 2:jianfa();break;
case 3:chengfa();break;
case 4:zhuan();break;
case 5:qiuni();break;
}

return 0;
}

⑼ c语言矩阵运算

#include<vector>
#include<iostream>
intmain()
{
usingnamespacestd;
intm,n,p;
vector<vector<int>>A,B,C;
cout<<"pleaseinputm,n,p"<<endl;
cin>>m>>n>>p;
vector<int>tmp;
intttp;
for(inti=0;i<m;i++)
{
for(intj=0;j<n;j++)
{
cin>>ttp;
tmp.push_back(ttp);
}
A.push_back(tmp);
tmp.clear();
}
for(inti=0;i<n;i++)
{
for(intj=0;j<p;j++)
{
cin>>ttp;
tmp.push_back(ttp);
}
B.push_back(tmp);
tmp.clear();
}
for(inti=0;i<m;i++)
{
for(intj=0;j<p;j++)
{
ttp=0;
for(intk=0;k<n;k++)
ttp=ttp+A[i][k]*B[k][j];
tmp.push_back(ttp);
}
C.push_back(tmp);
tmp.clear();
}
for(inti=0;i<m;i++)
{
for(intj=0;j<p;j++)
{
cout<<C[i][j]<<'';
}
cout<<endl;
}
system("pause");
}

现在是2017年10月15日,无意中回答了一道2011年12月09日的题,留念。

⑽ c语言编程矩阵运算

元素不可以定义变量,但是你可以这么理解,a[0]就是a, 但是a[0]可以做变量使用