编程序,显示螺旋方阵—java实现4*4螺旋方阵

将代码中的n修改,可实现任意n*n的螺旋方阵,也可将其改为输入值

package 课本例题;
//螺旋方阵.java
public class Test_2_3_螺旋方阵 {

	public static void main(String[] args) {
		// TODO 自动生成的方法存根
		int n=4;//螺旋方阵的行列数:4*4
        int	number=1;//数据的初始值
        int arry[][]=new int[n][n];//初始化一个n*n的二维数组用于存放数据
        int m;//m为螺旋方阵的螺旋圈数
        
        if(n%2==0)
        	m=n/2;//如果n为偶数,其螺旋圈数为n/2
        else
        	m=n/2+1;//如果n为奇数,其螺旋圈数为n/2+1
        
        for(int i=0;i<m;i++) {//i为当前的第i圈,从外到内螺旋m圈
        	for(int j=i;j<n-i;j++) {//从左往右的行,j为第几列
        		arry[i][j]=number;
        		number++;
        	}
        	for(int k=i+1;k<n-i;k++) {//从上往下的列,n-i-1为矩阵第几列,
        		//k为第几行,为了不与“从左往右的行”的最后一个数据重叠,故行数i+1即多+1往下移动一行
        		arry[k][n-i-1]=number;
        		number++;
        	}
        	for(int x=n-i-2;x>=i;x--) {//从右往左的行,n-i-1为矩阵的第几行
        		//x为第几列,为了不与“从上往下的列”的最后一个数据重叠,故列数x=n-i-2即多-1往左移动一列
        		arry[n-i-1][x]=number;
        		number++;
        	}
        	for(int y=n-i-2;y>i;y--) {//从下往上的列,i为矩阵的第几列
        		//y为第几行,为了不与“从右往左的行”的最后一个数据重叠,故行数y=n-i-2即多-1往上移动一行
        		//为了不与“从左往右的行”的第一个数据重叠,故行数y>i即多+1往下移动一行
        		arry[y][i]=number;
        		number++;
        	}
        }
        for(int i=0;i<n;i++) {
        	for(int j=0;j<n;j++) {
        		System.out.print(arry[i][j]+"\t");
        	}
        	System.out.println();//每输出完成一行就换行
        }
	}

}

运行结果截图
4*4螺旋方阵

  • 9
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值