螺旋填数Java实现

问题描述:

螺旋填数.
读入两个整数m,n, 输出一个m行n列的矩阵, 这个矩阵是1~m*n这些自然数按照右、 下、 左、 上螺旋填入的结果。
例如读入数字4,5, 则输出结果为:
1      2    3     4      5
14  15   16    17    6
13  20   19    18    7
12  11   10     9      8
 

本文定义了四个运动状态,过程略显复杂,用while循环进行实现,代码如下:

package Demo;
import java.util.Arrays;
import java.util.Scanner;
public class screwN {
	public static void main(String[] args) {
		Scanner sca1=new Scanner(System.in);
		System.out.println("请输入m:");
		int m=sca1.nextInt();
		Scanner sca2=new Scanner(System.in);
		System.out.println("请输入n:");
		int n=sca2.nextInt();
		int[][]scerw=new int[m][n];
		//控制运动方向(4个运动状态)
		int index=0;
		//控制行
		int i=0;
		//控制列
		int j=0;
		//数值
		int num=1;
		while (zero(scerw)) {
			//如果index等于3后,下一个状态应该是0
			index=(index==4)?0:index;
			//状态0:上(从左往右)
			if (index==0) {
				scerw[i][j]=num++;
				j++;
				if (j>=n) {
					j--;
					index++;
					
				}else {
					if (scerw[i][j]!=0) {
						index++;
						j--;
					}
					
				}
				
				
			}
			//状态1:右(从上往下)
			if (index==1) {
				scerw[i+1][j]=num++;
				i++;
				if ((i+1)>=m) {
					i--;
					index++;
					
				}else {
					if (scerw[i+1][j]!=0) {
						index++;
						i--;
					}
				}
				
			}
			//状态2:下(从右往左)
           if (index==2) {
        	   scerw[i+1][j-1]=num++;
        	   j--;
        	   if (j-1<0) {
        		   j++;
        		   index++;
				
			}else {
				if (scerw[i+1][j-1]!=0) {
					index++;
					j++;
				}
				
			}
        	   
			}
         //状态3:左(从下往上)
			if (index==3) {
				scerw[i][j-1]=num++;
				i--;
				if (i<=0) {
					i++;
					index++;
					
				} else {
					if (scerw[i][j-1]!=0) {
						index++;
						i++;
					}
				}
				
			}
		}
		
		for (int i1 = 0; i1 < scerw.length; i1++) {
			for (int k = 0; k < scerw.length; k++) {
				System.out.print(scerw[i1][k]+"\t");
			}System.out.println(" ");
			
		}
		
	}
	//构造一个判断是否填满非零的方法
	public static boolean zero(int[][] ss) {
		for (int i = 0; i < ss.length; i++) {
			for (int j = 0; j < ss[0].length; j++) {
				if (ss[i][j]==0) {
					return true;
				}
			}
		}
		return false;
	}
}

试了下结果,用的m=5,n=5:

1	2	3	4	5	 
16	17	18	19	6	 
15	24	25	20	7	 
14	23	22	21	8	 
13	12	11	10	9

 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值