欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

数据结构之矩阵行列和相等的实例

时间:2021-12-09 18:06:34|栏目:C代码|点击:

以下为展示“矩阵行列和相等”的简单示例:

1.用c语言实现的版本

#include <stdio.h> 
#include <math.h> 
 
void main() 
{ 
  int a[16][16],i,j,n,k; 
  printf("Please input n(1~15,it must be odd.): "); 
  scanf("%d",&n); 
  while(!(n>=1&&n<=15) || n%2==0) 
  { 
    printf("The number is invalid.Please insert again:"); 
    scanf("%d",&n); 
  } 
  //初始化数组 
  for(i=0; i<=n; ++i)  
  { 
    for(j=0; j<=n; ++j)  
    { 
      a[i][j]=0; 
    } 
  } 
 
  j = n/2 + 1; 
  a[1][j] = 1; 
  i = 1; 
  for(k=2; k<=n*n; ++k) 
  { 
    i = i - 1;  
    j = j + 1; 
    if(i==0 && j==n+1) //行列都越界 
    { 
      i = i+2; 
      j = j-1; 
    } 
    else  
    { 
      if(i==0) //行越界 
      { 
        i = n; 
      } 
      if(j==n+1) //列越界 
      { 
        j = 1; 
      } 
    } 
 
    if(a[i][j]==0) //如果里面没数字  
    { 
      a[i][j] = k; 
    } 
    else //得到新的数值 
    { 
      i = i + 2; 
      j = j - 1; 
      a[i][j] = k; 
    } 
  } 
 
  for(i=1; i<=n; ++i) 
  { 
    for(j=1; j<=n; ++j) 
    { 
      printf("%3d", a[i][j]); 
    } 
    printf("\n"); 
  } 
} 

2.用C++语言实现的版本

#include <iostream> 
#include <math.h> 
 
void main() 
{ 
  int a[16][16],i,j,n,k; 
  std::cout<<"Please input n(1~15,it must be odd.): "; 
  std::cin>>n; 
  while(!(n>=1&&n<=15) || n%2==0) 
  { 
    std::cout<<"The number is invalid.Please insert again:"; 
    std::cin>>n; 
  } 
  初始化数组 
  for(i=0; i<=n; ++i)  
  { 
    for(j=0; j<=n; ++j)  
    { 
      a[i][j]=0; 
    } 
  } 
 
  i = 0; 
  j = n/2; 
  a[i][j] = 1; 
  for(k=2; k<=n*n; ++k) 
  { 
    i = i - 1;  
    j = j + 1; 
    if(i<=-1 && j>=n) //行列都越界 
    { 
      i = 1; 
      j = n - 1; 
    } 
    else  
    { 
      if( i<=-1 ) //行越界 
      { 
        i = n - 1; 
      } 
      if(j>=n) //列越界 
      { 
        j = 0; 
      } 
    } 
 
    if(a[i][j]==0) //如果里面没数字  
    { 
      a[i][j] = k; 
    } 
    else //得到新的数值 
    { 
      i = i + 2; 
      j = j - 1; 
      a[i][j] = k; 
    } 
  } 
 
  for(i=0; i<=n-1; ++i) 
  { 
    for(j=0; j<=n-1; ++j) 
    { 
      printf("%3d", a[i][j]); 
    } 
    printf("\n"); 
  } 
} 

运行结果如下图所示:

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

上一篇:C语言实现文件读写操作

栏    目:C代码

下一篇:浅析C语言中的数组及字符数组

本文标题:数据结构之矩阵行列和相等的实例

本文地址:http://www.codeinn.net/misctech/186256.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有