Распечатайте форму ромба с помощью Java

Я хочу напечатать форму сетки на выходной консоли в Eclipse.

Пример ромба

По сути, я взял у пользователя целое число, которое представляет собой количество звезд на одной границе сетки.

Вот код, который у меня есть до сих пор:

public class PrintDiamond {
    public static void main(String[] args) {
        System.out.print("Enter the number: ");
        Scanner scan = new Scanner(System.in);
        int num = scan.nextInt();
        num--;
        for (int i = num; i > 0; --i) {
            //Insert spaces in order to center the diamond
            for (int n = 0; n < i; ++n) {
                System.out.print("  ");
            }
            System.out.print(" *");
            for (int n = i; n < num; ++n) {
                System.out.print(" + ");
                System.out.print(" ");
            }//Ending bracket of nested for-loop
            System.out.println();
        }//Ending bracket of for loop
        //Print out a diamond shape based on user input
        for (int i = 0; i <= num; ++i) {//<= to print the last asterisk
            //Insert spaces in order to center the diamond
            for (int n = 0; n < i; ++n) {
                System.out.print("  ");
            }
            System.out.print(" *");
            for (int n = i; n < num; ++n) {
                System.out.print(" + ");
                System.out.print(" ");
            }//Ending bracket of nested for-loop
            System.out.println();
        }//Ending bracket of for loop
    }
}

и вывод (для инт. 6):

           *
         * +  
       * +   +  
     * +   +   +  
   * +   +   +   +  
 * +   +   +   +   +  
   * +   +   +   +  
     * +   +   +  
       * +   +  
         * +  
           *

person Firat    schedule 02.11.2016    source источник


Ответы (4)


Вот код:

public static void main(String[] args) {
    System.out.print("Enter the number: ");
    Scanner scan = new Scanner(System.in);
    int num = scan.nextInt();
    final char[][] diamond = makeDiamond(num);
    for (int i = 0; i < diamond.length; i++) {
        for (int j = 0; j < diamond[i].length; j++) {
            System.out.print(diamond[i][j]);
        }
        System.out.println();
    }
}

public static char[][] makeDiamond(int n) {
    int width = 1 + 4 * (n - 1);
    int height = 1 + 2 * (n - 1);
    char[][] out = new char[height][width];
    int x0 = 2 * (n - 1);
    int y0 = n - 1;
    for (int i = 0; i < width; i += 2) {
        // Top borders
        int y1 = Math.abs(y0 - i / 2);
        out[y1][i] = '*';

        // Bottom borders
        int y2 = height - Math.abs(i / 2 - y0) - 1;
        out[y2][i] = '*';

        if ((x0 - i) % 4 == 0) {
            // Plus signs
            for (int j = y1 + 1; j < y2; j++) {
                out[j][i] = '+';
            }
        }
    }
    return out;
}
person Vladimir Petrakovich    schedule 03.11.2016

Несколько советов для вашего решения:

  • Создайте метод печати «алмазного ряда» для заданной ширины ряда и заданной общей ширины ромба.
  • Создайте инструментальный метод для печати заданного количества пробелов.
  • В вашем основном способе должно быть две простые петли: одна для верхней, другая для нижней половины.
  • Магия заключается в методе печати одной строки ромба для заданных двух параметров w и n.

Это всегда хороший подход - свести вашу сложную проблему к проблеме с меньшей сложностью - в этом случае путем создания методов и их использования, например. в петлях.

В вашем методе печати одного ряда ромбов вам нужно будет проверить, находитесь ли вы в «нечетном» или «четном» ряду.

person Florian Albrecht    schedule 03.11.2016

Хорошо, это похоже на школьное задание, поэтому я не буду писать код.

Сначала вам нужно понять и написать в псевдокоде или просто на английском языке, что вы хотите сделать:

  • Instructions on how to draw the grid.
    • How many lines should I print?
    • Какова длина каждой строки?
    • Как узнать, нужно ли мне печатать + или нет?
  • General steps of your program.
    • Read size of the grid, N.
    • Если N ‹ 1, запросите еще раз (или выйдите из программы).
    • Если N = 1 или больше, распечатайте сетку.
  • Detailed sub-steps of your program.
    • Print the grid
      • Loop for number of lines.
      • Создать пустой массив/буфер/список/строку с правильной длиной для текущей строки.
      • ...

Потому что сейчас кажется, что ты ничего не понял. И если это так, то ваша проблема связана не с Java, а с базовыми знаниями в области программирования, которых вы не получите, если мы просто напишем для вас алгоритм.

person walen    schedule 03.11.2016

Два вложенных цикла for от -n до n и один оператор if else. Нулевая точка находится в центре ромба, а граница получается, когда:

Math.abs(i) + Math.abs(j) == n

Попробуйте онлайн!

public static void main(String[] args) {
    printDiamond(0);
    printDiamond(2);
    printDiamond(5);
}

static void printDiamond(int n) {
    System.out.println("n=" + n);
    for (int i = -n; i <= n; i++) {
        for (int j = -n; j <= n; j++)
            if (Math.abs(i) + Math.abs(j) == n)
                System.out.print("*  ");
            else if (Math.abs(i) + Math.abs(j) < n && j % 2 == 0)
                System.out.print("+  ");
            else
                System.out.print("   ");
        System.out.println();
    }
}

Выход (объединенный):

n=0 n=2 n=5
*  










      *        
* + *
* + *
* + *
*






               *                 
* + *
* + *
* + + + *
* + + + *
* + + + + + *
* + + + *
* + + + *
* + *
* + *
*

См. также: Печать ромба ASCII из звездочек

person Community    schedule 01.07.2021