简单图形打印(需求分解)

Posted 那么长的代码

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了简单图形打印(需求分解)相关的知识,希望对你有一定的参考价值。

打印任意高度的实心菱形

  菱形的打印是一个相对复杂的需求,我们需要把它分解成为多个简单的需求来完成。

     

  将它看作是两个部分,上面一个三角形,下面一个倒三角形。

  再依次实现打印。

代码如下:

//打印任意高度的菱形
public class GetDiamond {
    public static void main(String[] args) {
        getSolidDiamond(9);//传入菱形的高度
  }
    /**
         打印高度为10的实心菱形
         参数high是菱形的高度
     */
    private static void getSolidDiamond(int high) {
        /*
            打印菱形的上半部分
         */
        //Math.round(high/2)菱形的上半部分的行数
        for (int column = 1; column <= Math.round(high / 2); column++) {
            //前面的打印空格,空格个数为高度一半减一个
            for (int row = 0; row < Math.round(high / 2) - column; row++) {
                System.out.print(" ");
            }
            //打印“*”个数,“*”的个数等于行数乘2减一个
            for (int count = 0; count < column * 2 - 1; count++) {
                System.out.print("*");
            }
            //每打印完一行,换一行
            System.out.println();
        }

        /*
             菱形的下半部分,与上半部分对称
          */
        for (int column = Math.round(high / 2) - 1; column >= 1; column--) {
            //打印前面的空格,空格个数为总高度的1/2减去当前行数
            for (int row = 0; row < Math.round(high / 2) - column; row++) {
                System.out.print(" ");
            }
            //打印“*”个数,“*”的个数等于行数乘2减一个
            for (int count = 0; count < column * 2 - 1; count++) {
                System.out.print("*");
            }
            //每打印完一行,换一行
            System.out.println();

        }

    }
}
==================
运行结果: 
   *
  ***
 *****
*******
 *****
  ***
   *

打印任意高度的空心菱形

  

  依旧分成上下两个部分,依次解决。

//打印任意高度的菱形
public class GetDiamond {
    public static void main(String[] args) {
        getHollowDiamond(9);//传入菱形的高度
    }

    /**
         打印高度为10的空心菱形
         参数high是菱形的高度
     */
    private static void getHollowDiamond(int high) {
        /*
             打印菱形的上半部分
         */
        //Math.round(high/2)四舍五入方法,菱形的上半本分的行数
        for (int column = 1; column <= Math.round(high / 2); column++) {
            //前面的空格数,空格的个数为总高度的1/2减当前行数
            for (int row = 0; row < Math.round(high / 2) - column; row++) {
                System.out.print(" ");
            }
            //打印中间*,第一行没有星号
            if (column != 1) {
                System.out.print("*");
            }
            //打印中间空格数,每一行有当前行数减一乘二减一个空格
            for (int row = 0; row < (column - 1) * 2 - 1; row++) {
                System.out.print(" ");
            }
            //每一行都有一个菱形
            System.out.println("*");
        }
            /*
                 菱形的下半部分与上半部分对称
             */
            //Math.round(high/2)四舍五入方法,菱形的上半本分的行数
            for (int column = Math.round(high / 2) - 1; column >= 1; column --) {
                //前面的空格数,空格的个数为总高度的1/2减当前行数
                for (int row = 0; row < Math.round(high / 2) - column; row++) {
                    System.out.print(" ");
                }
                //打印中间*,第一行没有星号
                if (column != 1) {
                    System.out.print("*");
                }
                //打印中间空格数,每一行有当前行数减一乘二减一个空格
                for (int row = 0; row < (column - 1) * 2 - 1; row++) {
                    System.out.print(" ");
                }
                //每一行都有一个菱形
                System.out.println("*");
            }
    }
===================
运行结果:
   *
  * *
 *   *
*     *
 *   *
  * *
   *

   这个例子是让我们增强对复杂业务的分析能力。当我们得到一个复杂的业务时候,任何人都不可能一次性将代码写出来,我们要对它进行分析,将它分解为多个简单的需求,然后一一实现。

以上是关于简单图形打印(需求分解)的主要内容,如果未能解决你的问题,请参考以下文章

循环嵌套-打印不定长特殊*号图形

设计用于分解需求预测的简单模式

C语言打印图形

动态规划解最长公共子序列(LCS)问题 (附可打印LCS完整代码)

argparse 代码片段只打印部分日志

createjs 绘制圆形图片