C语言 简单的矩阵生成

C语言 简单的矩阵生成,第1张

i=i+1;//这里你i加了1造成下面的for循环不成立
a[i][j]=count;
count++;
for (;i==0;)上面你给i加了1,使得i不等于0,for语句循环条件也就不成立。所以不进循环。
下面另一个循环不进也是相同原因。

题目要求有一个问题,它要求N最小为2,却要求N为奇数,N为奇数应该最小为3或1才对

按照题目要求编写的C语言矩阵程序如下

#include<stdioh>

int main(){

int i,j,k,N,count=1;

scanf("%d",&N);

if(N<=2 || 15<N || N%2==0){

printf("请输入小于等于15且大于2的奇数");

}else{

int a[N][N];

for(i=N/2;i>=0;i--){

k=N-i-1;

for(j=N-i-2;j>=i;j--){

  a[j][k]=count++;

}

for(j=N-i-2;j>=i+1;j--){

  a[i][j]=count++;

}

for(j=i;j<N-i;j++){

  a[j][i]=count++;

}

for(j=i+1;j<N-i;j++){

  a[k][j]=count++;

}

}

for(i=0;i<N;i++){

for(j=0;j<N;j++){

  printf("%-5d",a[i][j]);

}

printf("\n");

}

}

return 0;

}

#include<stdioh>
#include<stdlibh>
int main()
{
int n,p,i,j;
scanf("%d",&n);
p=new int[n];
for(i=0;i<n;i++)
{
p[i]=new int[n];
for(j=0;j<n;j++) scanf("%d",&p[i][j]);
}
for(i=0;i<n;i++)
{
printf("%d",p[i][0]);
j=1;
while(j<n)
{
printf(" %d",p[i][j]);
j++;
}
printf("\n");
}
return 0;
}

c语言矩阵分为两种:

第一种方法是动态的申请矩阵存储空间,该方法的好处有以下两点:

1能够动态的申请和释放存储空间;

2对于将矩阵作为函数返回值的情况,该方法具有独特的优势。

第二种方法是静态存储实现,该方法的好处是简单、易实现,相对第一种方法缺点:

1静态实现,不能动态的申请和释放空间,对电脑的内容要求高;

2对于将矩阵作为函数返回值的情况,不能使用该方法。

用C语言编写程序(两个矩阵相加)代码如下:

/

MatrixAdditionc

实现两个矩阵相加

/

#include<stdioh>

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;i<3;i++)//控制行

{

for(j=0;j<4;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;i<3;i++)//控制行

{

for(j=0;j<4;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;i<3;i++)//控制行

{

for(j=0;j<4;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;i<3;i++)//控制行

{

for(j=0;j<4;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语言

把程序编写好了,已经运行过:

#include<stdioh>
int main()
{
int a[10][10],n;
int i,j;
printf("输入数字矩阵的维数(1<n<10) n= ");
scanf("%d",&n);
if(n<2||n>9)return 0;
printf("\n请输入%d个元素:\n",nn);
for(i=0;i<n;i++)for(j=0;j<n;j++)scanf("%d",&a[i][j]);
printf("\n你输入的矩阵为:\n");
for(i=0;i<n;i++){for(j=0;j<n;j++)printf("%3d",a[i][j]);printf("\n");}
return 0;
}

有什么问题留言。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/13154440.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-06-12
下一篇 2023-06-12

发表评论

登录后才能评论

评论列表(0条)

保存