CoreJava逻辑思维-顺时针打印自定义矩阵
CoreJava逻辑思维-顺时针打印自定义矩阵
这两天回顾了一下刚入Java时的一些比较有意思的逻辑题,曾经也费劲脑汁的思考过的一些问题,比如百钱百鸡最简单的算法啦之类的,而今天博主想说的是一个循环打印指定字符的一道问题。上题目。
从控制台输入两个数字代表矩阵的行列数,并顺时针回旋打印出从1-矩阵可以存放元素的个数
例:接收数据 4 4 ,则打印出的图形为:
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
此处博主只给出了一种解决方案,欢迎有想法的小伙伴可以给出更简单的方法。
博主以前的解决方案为(为什么说以前呢,因为最近真的是没什么时间去考虑新方法了)
思路
既然是个矩阵,那么博主首先想到的就是使用二维数组来解决此事,那么问题来了,如何将1-m*n按照这样的规律存进数组便是解体的关键(其实跟没说一样,知道这种规律直接打印好了)
闲话不多说,现在博主召唤出四大圣使来解决这个问题吧。
朱雀:第一行,我是自增的。
白虎:最后一列,我也是自增的。
玄武:最后一行,我是递减的!!
青龙:第一列,除去第一个元素我也是递减的。
艾玛,别说了,博主知道了,
//定义一个二维数组,用来存储矩阵元素
int[][] array = new int[m][n];
//定义两个变量,用来控制待填充元素的位置
int i,j;
//定义一个计数器,用来代表矩阵元素。
int count = 0;
准备的差不多了。那就上代码吧~最笨的方法见下。
/*计数器*/
private static int count = 0;
/**/
private static int i = 0;
/*控制台接收输入参数*/
private static Scanner input = new Scanner(System.in);
//程序入口
public static void main(String[] args) {
System.out.println("请输入两个数作为行列");
int m = input.nextInt();
int n = input.nextInt();
/*初始化一个m行n列的二维数组*/
int[][] array = new int[m][n];
/*初始值设为1*/
int num = 1;
count = m / 2;
if (m % 2 != 0) {
count++;
}
int sum = m * n ;
//对元素进行排序
array = getNums(array, m, n, num,sum);
//打印数组元素
printArray(array, m, n);
input.close();
}
/**
* 根据输入行列值初始化数据
*
* @param array 空数组
* @param m 行
* @param n 列
* @param num 数据从1开始
* @return 赋值后数组
*/
private static int[][] getNums(int[][] array, int m, int n, int num,int sum) {
//遍历行
for (int j = i; j < n; j++) {
array[i][j] = num;
num++;
if (num > sum) {
return array;
}
}
//固定列,四边形最右边的数据
for (int j = i + 1; j < m; j++) {
array[j][n - 1] = num;
num++;
if (num > sum) {
return array;
}
}
//固定行,四边形最下面的数据
for (int j = n - 2; j > i; j--) {
array[m - 1][j] = num;
num++;
if (num > sum) {
return array;
}
}
//固定列,四边形最左边一列的数据
for (int j = m - 1; j > i; j--) {
array[j][i] = num;
num++;
if (num > sum) {
return array;
}
}
n--;
m--;
i++;
if (i == count) {
return array;
}
return getNums(array, m, n, num,sum);
}
/**
* 输出数组中所有元素
*
* @param array 待输出数组
* @param m 行
* @param n 列
*/
private static void printArray(int[][] array, int m, int n) {
for (int i = 0; i < m; i++) {
for (int j = 0; j < n; j++) {
System.out.print(array[i][j] + "\t");
}
//空行
System.out.println();
}
}
接下来,上结果图~~~

可以联系博主哟~~
邮箱:ycountjavaxuan@outlook.com
CoreJava逻辑思维-顺时针打印自定义矩阵的更多相关文章
- 剑指offer十九之顺时针打印矩阵
一.题目 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2, ...
- 【剑指offer】顺时针打印矩阵
转载请注明出处:http://blog.csdn.net/ns_code/article/details/26053049 剑指offer上的第20题,九度OJ上測试通过. 题目描写叙述: 输入一个矩 ...
- 51. 顺时针打印矩阵[print matrix in clockwise direction]
[本文链接] http://www.cnblogs.com/hellogiser/p/print-matrix-in-clockwise-direction.html [题目] 输入一个矩阵,按照从外 ...
- php笔试算法题:顺时针打印矩阵坐标-蛇形算法
这几天参加面试,本来笔试比较简单,但是在面试的时候,技术面试官说让我现场写一个算法,顺时针打印矩阵的坐标,如图所示 顺序为,0,1,2,3,4,9,14,19,24,23,22,21,20,15,10 ...
- 《剑指offer》— JavaScript(19)顺时针打印矩阵
顺时针打印矩阵 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打 ...
- 剑指offer得意之作——顺时针打印矩阵
题目: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3 ...
- [PHP] 算法-顺时针打印矩阵的PHP实现
1.行数和列数取出来row,col,圈数就是 (较小值-1)/2+1 2.外层循环控制圈数,内层四个for循环,i 3.第一个for循环,从左到右,j=i;j<col-i;j++;j<; ...
- 《剑指offer》顺时针打印矩阵
本题来自<剑指offer> 顺时针打印矩阵 题目: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 1 ...
- 【Java】 剑指offer(29) 顺时针打印矩阵
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字. 思 ...
随机推荐
- Thrift全面介绍
官网:http://thrift.apache.org 简介 Thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java ...
- [转载] Redis资料汇总专题
转载自http://www.cnblogs.com/tommyli/archive/2011/12/14/2287614.html 1.Redis是什么? 十五分钟介绍 Redis数据结构 Redis ...
- 浅谈Verilog HDL代码编写风格
消失了好久,没有写文章,也没有做笔记,因为最近再赶一个比赛,时间很紧,昨天周六终于结束了,所以趁着周末这会儿有时间,写点东西,记录下来.首先我学习FPGA才一年多,我知道自己没有资格谈论一些比较深层次 ...
- Linux nc 命令传输文件
NAME nc - arbitrary TCP and UDP connections and listensSYNOPSIS nc [-46DdhklnrStUuvz] [-i interv ...
- javascript第十章--Ajax与Comet
① XMLHttpRequest对象 ② XMLHttpRequest2级 ③ 进度事件 ④ 跨域源资源共享 ⑤ 其他跨域技术
- 猪圈密码python脚本实现
CTF比赛中,MISC题型中有时候会考到一种一种叫做"猪圈密码"(Pigpen_chiper)的简单加密方式.网上有个表可以对照地来实现解密,但是实际中太慢不符合竞速思维,于是写一 ...
- 《Linux命令行与shell脚本编程大全》第十六章 控制脚本
一些控制脚本的方式:向脚本发送信号.修改脚本优先级,在脚本运行时切换到运行模式 16.1 处理信号 linux利用信号与运行在系统中的进程进行通信. 也可以通过对脚本进行编程,使其在收到特定信号时执行 ...
- TestLink使用
- 【二十二】mysqli事务处理
事务处理 事务基本原理 如果不开启事务,执行一条sql,马上会持久化数据.可见:默认的mysql对sql语句的执行是自动提交的! 如果开启了事务,就是关闭了自动提交的功能,改成了commit执行自动提 ...
- mysql 双机热备注意事项
上一篇文章已经介绍过 主从复制, 本文对主从复制只是简单描述,如对主从复制不清楚的,可以先看上一篇文章 主从复制 一:介绍 mysql版本:5.7.20 第一个主服服务器ip:192. ...