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逻辑思维-顺时针打印自定义矩阵的更多相关文章

  1. 剑指offer十九之顺时针打印矩阵

    一.题目 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2, ...

  2. 【剑指offer】顺时针打印矩阵

    转载请注明出处:http://blog.csdn.net/ns_code/article/details/26053049 剑指offer上的第20题,九度OJ上測试通过. 题目描写叙述: 输入一个矩 ...

  3. 51. 顺时针打印矩阵[print matrix in clockwise direction]

    [本文链接] http://www.cnblogs.com/hellogiser/p/print-matrix-in-clockwise-direction.html [题目] 输入一个矩阵,按照从外 ...

  4. php笔试算法题:顺时针打印矩阵坐标-蛇形算法

    这几天参加面试,本来笔试比较简单,但是在面试的时候,技术面试官说让我现场写一个算法,顺时针打印矩阵的坐标,如图所示 顺序为,0,1,2,3,4,9,14,19,24,23,22,21,20,15,10 ...

  5. 《剑指offer》— JavaScript(19)顺时针打印矩阵

    顺时针打印矩阵 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打 ...

  6. 剑指offer得意之作——顺时针打印矩阵

    题目: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3 ...

  7. [PHP] 算法-顺时针打印矩阵的PHP实现

    1.行数和列数取出来row,col,圈数就是 (较小值-1)/2+1 2.外层循环控制圈数,内层四个for循环,i 3.第一个for循环,从左到右,j=i;j<col-i;j++;j<; ...

  8. 《剑指offer》顺时针打印矩阵

    本题来自<剑指offer> 顺时针打印矩阵 题目: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 1 ...

  9. 【Java】 剑指offer(29) 顺时针打印矩阵

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字. 思 ...

随机推荐

  1. [转载] 解读ClassLoader

    转载自http://www.iteye.com/topic/83978 ClassLoader一个经常出现又让很多人望而却步的词,本文将试图以最浅显易懂的方式来讲解 ClassLoader,希望能对不 ...

  2. Python闭包

    1.概述 闭包是在其词法上下文中引用自由变量的函数. >>> def foo(): ... m=3 ... n=5 ... def bar(): ... a=4 ... return ...

  3. tornado之子模板

    #!/usr/bin/env python26 #-*- coding:utf8 -*- import tornado.httpserver import tornado.ioloop import ...

  4. yaml在python中的应用简单整理

    #简单介绍============================================================== YAML使用寄主语言的数据类型,这在多种语言中流传的时候可能会引 ...

  5. js判断手机或Pc端登陆.并跳转到相应的页面

    <script src="~/Web/js/jquery-1.10.1.min.js"></script> <script> $(functio ...

  6. 《用Java写一个通用的服务器程序》01 综述

    最近一两年用C++写了好几个基于TCP通信类型程序,都是写一个小型的服务器,监听请求,解析自定义的协议,处理请求,返回结果.每次写新程序时都把老代码拿来,修改一下协议解析部分和业务处理部分,然后就一个 ...

  7. 《java.util.concurrent 包源码阅读》18 Exchanger

    Exchanger可以看做双向数据传输的SynchronousQueue,即没有生产者和消费者之分,任意两个线程都可以交换数据. 在JDK5中Exchanger被设计成一个容量为1的容器,存放一个等待 ...

  8. ORACLE 错误代码提示归集

    有时数据库出现问题,不是每次都有网络可查,所以把所有的ora系列的错误整理出来, 在最没有办法的时候,需要自己来解决,有了这些根据,问题会好办的.虽说对于数据库方面, DBA很强大,他们在遇到错误时, ...

  9. Ckeditor与Ckfinder的配合使用,上传图片、水印、修改图片名字为当前日期 asp.net

    为了配置出来上传功能,并且还添加水印,修改图片的名字为日期,真的头疼了很久,现在来分享一下自己所做的,也算一点小小的成就吧,顺带帮帮很多还在弄这个的猿们.我是分别用了两种方法.先说低版本的Versio ...

  10. C语言结构体1.1

    结构体组成 struct 结构体名: 类型名  成员名: 建立结构体 结构体名 类型名 { 成员: }: 建立一个关于学生信息的结构体(名字,年龄,性别,学号,成绩): 结构体定义 //结构体声明 s ...