1. 程式人生 > >Java小程式:列印空心菱形

Java小程式:列印空心菱形

像比較複雜的問題我們可以先從簡單的做起,一步一步完善。比如我們要打印出空心菱形,可以沿著”金字塔—>空心金字塔—>空心菱形“這一思路進行。具體實現方式如下:
一、金字塔

public class Demo1
{
    public static void main(String []args)
    {
        int lay=5;
        for (int i=1;i<=lay;i++) //i表示金字塔行數
        {
            for (int j=1;j<=lay-i;j++) //j表示每行第一個"*"號前面的空格數
            {
                System.out
.print(" "); } for (int k=1;k<=2*i-1;k++) //k表示每行要列印的"*"號 { System.out.print("*"); } System.out.println(); } } }

執行結果如下:
這裡寫圖片描述

二、鏤空金字塔
鏤空金字塔與完整金字塔比較,可以看出除了金字塔的各個邊上是” * “號外,金字塔的內部全是用空格代替了” * “號。因此可以在列印每行的” * “號時判斷是不是第一個” * “或者最後一個”*”,如果不是則用空格替換掉。

public class Demo2
{
    public static void main(String []args)
    {
        int lay=5;
        for (int i=1;i<=lay;i++) //i表示金字塔行數
        {
            for (int j=1;j<=lay-i;j++) //j表示每行"*"號前面的空格數
            {
                System.out.print(" ");
            }
            for (int k=1;k<=2
*i-1;k++) //k表示每行要列印的"*"號 { if (i==1||i==lay) //如果是第一行或最後一行則將"*"全部打印出來 { System.out.print("*"); } else if (k==1||k==2*i-1) //如果要列印的"*"是第一個或最後一個則打印出來 { System.out.print("*"); } else System.out.print(" "); //如果要列印的"*"不是第一個或最後一個則列印空格 } System.out.println(); } } }

這裡寫圖片描述

三、空心菱形
空心菱形可以看作兩部分組成:上半部分和下半部分。而這兩部分均屬於空心金字塔型別。

public class Demo3
{
    public static void main(String []args)
    {
        int lay=5;
        for (int i=1;i<=lay;i++) //i表示空心菱形上半部分行數;類似於金字塔行數
        {
            for (int j=1;j<=lay-i;j++) //j表示每行"*"號前面的空格數
            {
                System.out.print(" ");
            }
            for (int k=1;k<=2*i-1;k++) //k表示每行要列印的"*"號
            {
                 if (k==1||k==2*i-1) //如果要列印的"*"是第一個或最後一個則打印出來
                {
                    System.out.print("*");
                }
                else
                    System.out.print(" "); //如果要列印的"*"不是第一個或最後一個則列印空格
            }
            System.out.println();
        }        //以上打印出來的是空心菱形的上半部分
        for (int i=1;i<=lay-1;i++)  //空心菱形下半部分的行數為lay-1行;比如上半部分4行,則下半部分為3行才能構成菱形
        {
            for (int j=1;j<=i;j++) //每行空格數
            {
                System.out.print(" ");
            }
            for (int k=1;k<=2*(lay-i)-1;k++) //下半部分每行總的"*"數
            {
                if (k==1||k==2*(lay-i)-1) //如果"*"處在第一和最後一位則打印出來
                {
                    System.out.print("*");
                }else
                    System.out.print(" "); //如果"*"不是處在第一和最後一位則打印出空格
            }
            System.out.println();
        }       
    }
}

這裡寫圖片描述