【Java】回形数
回形数
键盘读入一个整数n(1-20),以n为矩阵大小,把1,2,3,4,5…按顺时针螺旋的形式填入。

import java.util.Scanner;
public class HuiXingShu {
public static void main(String[] args) {
System.out.print("请输入一个整数:");
int lenth;
Scanner scanner = new Scanner(System.in);
lenth = scanner.nextInt();
int[][] array = new int[lenth][lenth];
int direction = 1;//判断方向,1从左往右,2从上往下,3从右往左,4从下往上。
int i = 0;
int j = 0;
int k;
for(k = 1;k <= lenth * lenth;k++) {
if(direction == 1) {
if(j < lenth && array[i][j] == 0)//不能先判断数组中元素是否为零,可能会越界
array[i][j++] = k;
else {
direction = 2;//更换方向为从上到下
k--;//这个数没有赋给数组,过了这轮循环又会加一,所以先减一
i++;//这一行已经填满数,往下挪一行
j--;//下标已经越界,往回挪一列
}
}
else if(direction == 2) {
if(i < lenth && array[i][j] == 0)//不能先判断数组中元素是否为零,可能会越界
array[i++][j] = k;
else {
direction = 3;//更换方向为从右到左
k--;//这个数没有赋给数组,过了这轮循环又会加一,所以先减一
j--;//这一列已经填满数,往左挪一列
i--;//下标已经越界,往上挪一行
}
}
else if(direction == 3) {
if(j >= 0 && array[i][j] == 0)//不能先判断数组中元素是否为零,可能会越界
array[i][j--] = k;
else {
direction = 4;//更换方向为从下到上
k--;//这个数没有赋给数组,过了这轮循环又会加一,所以先减一
i--;//这一行已经填满数,往上挪一行
j++;//下标已经越界,往回挪一列
}
}
else if(direction == 4) {
if(i >= 0 && array[i][j] == 0)//不能先判断数组中元素是否为零,可能会越界
array[i--][j] = k;
else {
direction = 1;//更换方向为从左到右
k--;//这个数没有赋给数组,过了这轮循环又会加一,所以先减一
j++;//这一列已经填满数,往右挪一列
i++;//下标已经越界,往下挪一行
}
}
}
//遍历输出
for(int[] x : array) {
for(int y : x)
System.out.printf("%3d",y);
System.out.println();
}
}
}
【Java】回形数的更多相关文章
- Java实现回形数,只利用数组、循环和if-else语句
import java.util.Scanner; public class learn { public static void main(String[] args){ System.out.pr ...
- java參数传递机制浅析
欢迎转载,转载请声明出处! ----------------------------------------- 前言: java语言中,參数的传递仅仅有一种机制.那就是值传递. 举例: 以下将通过几个 ...
- java线程数过高原因分析
作者:鹿丸不会多项式 出处:http://www.cnblogs.com/hechao123 转载请先与我联系. 一.问题描述 前阵子我们因为B机房故障,将所有的流量切到了A机房,在经历了推送+ ...
- java參数传递方式问题
java的參数传递方式到底是值传递还是引用传递,这一直是一个争论不休的问题,一直以来没有形成统一意见. 在这里,我也仅仅是说一说个人见解,不保证是对的,全当是抛砖引玉. 首先我的观点是java採用的是 ...
- Java參数传递方式
原文:http://blog.sina.com.cn/s/blog_59ca2c2a0100qhjx.html,我作了些改动并添加了一个实例,添加对照 本文通过内存模型的方式来讨论一下Java中的參数 ...
- Java将数据以Excel文件形式导出后台代码实现
下面代码实现所需jar包: tomcat-embed-core-8.5.11.jar: commons-lang3-3.0.1.jar: commons-io-2.5.jar: poi-3.9.jar ...
- java猜数游戏
java随机数的产生 int number=(int)(Math.random()*10+1) Math.random()*n //n个随机数,从0开始 do{}while循环 //猜数,1到10的随 ...
- java猜数游戏(新手记录每天的作业)
//导入包 import java.util.Scanner;import java.util.Random; //定义一个类 public class Zcs{ //公共静态的主方法 public ...
- JAVA取数两个数组交集,考虑重复和不重复元素
1.考虑不重复元素,重复元素不添加 import java.awt.List; import java.util.ArrayList; import java.util.TreeSet; public ...
随机推荐
- DIgSILENT PowerFactory 15.1.7 破解过程
将dll文件复制到安装路径下:
- 【WP】攻防世界-杂项-Misc
长期更新一波 攻防世界 的杂项题解 这东西主要靠积累吧 攻防世界:https://adworld.xctf.org.cn 因为攻防世界的题目顺序经常变化,我也不改序号了,顺着之前写的位置往下写,推荐使 ...
- SP16033 TIPTOP - Tip Top Game 题解
Description Alim 和 Sufian 是好朋友.他们最近找到了一个好玩的游戏,叫做 Tip Top.游戏规则如下: 确定一个整数. 找出这个整数的所有因子. Alim 先手,每人轮流取一 ...
- linux 下查看文件修改时间
linux 下查看文件修改时间 等 http://blog.sina.com.cn/s/blog_6285b04e0100f4xr.html 查看文件时间戳命令:stat awk.txtFile: ` ...
- 【LeetCode】666. Path Sum IV 解题报告 (C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 DFS 日期 题目地址:https://leetcod ...
- 【LeetCode】329. Longest Increasing Path in a Matrix 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题目地址: https://leetcode.com/problems/longest- ...
- 【LeetCode】33. Search in Rotated Sorted Array 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...
- 1109 01组成的N的倍数
1109 01组成的N的倍数 基准时间限制:1 秒 空间限制:131072 KB 给定一个自然数N,找出一个M,使得M > 0且M是N的倍数,并且M的10进制表示只包含0或1.求最小的M. ...
- 1370 - Bi-shoe and Phi-shoe
1370 - Bi-shoe and Phi-shoe PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 3 ...
- ZOJ 1141:Closest Common Ancestors(LCA)
Closest Common Ancestors Time Limit: 10 Seconds Memory Limit: 32768 KB Write a program that tak ...