由外向裏的螺旋數組


#include <stdio.h>
#include <iostream>
#include<iomanip>
using namespace std;
#define N  5//行數
#define M  5 //列數


void main()
{
int a[N][M];
a[N/2][M/2]=N*M;//中間爲零
int p=1;


int hang=N/2;
int lie=M/2;
int o=N/2;//
for(;o>0;o--)//
{int k=2*o-1;//
int r=N/2+o;//
int l=N/2-o;//
int t=M/2-o;//
int b=M/2+o;//
  for(int i=0;i<=r-l;i++)//右列
 a[t][l+i]=p++;//
  for(int j=1;j<=b-t;j++)
 a[t+j][r]=p++;//
for(int z=1;z<=r-l;z++)
a[b][r-z]=p++;//
for(int d=1;d<b-t;d++)
a[b-d][l]=p++;//
 




}
for(int i=0;i<M;i++)
for(int j=0;j<N;j++)
{
cout<<setw(3)<<a[i][j]<<' ';
if(j==M-1)
cout<<endl;;
}




}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章