Java Строка квадратный узор - PullRequest
0 голосов
/ 18 января 2019

Пользователь вводит строку, а метод рисует квадрат. Например:

  • Для ввода = ram метод рисует:
    r r r
    - a -
    m m m
  • Для ввода = code метод рисует:
    c c c c
    - o o -
    - d d -
    e e e e
  • Для ввода = coder метод рисует:
    c c c c c
    - o o o -
    - - d - -
    - e e e -
    r r r r r

Пока мне удалось нарисовать что-то вроде этого:
c - - - c
- o - o -
- - d - -
- e - e -
r - - - r

Используя этот код:

static void pattern(String n) {
        int len = n.length();

        for (int i = 0; i < len; i++) {
            for (int j = 0; j < len; j++) {
                if((i==j)||(i==len-j-1)) {
                    System.out.printf("%c ", n.charAt(i));
                } else {
                    System.out.printf("- ");
                }
            }
            System.out.printf("%n");
        }

    }

Мне удалось распечатать только по диагонали, используя if((i==j)||(i==len-j-1)), но я не знаю, как бы я мог сделать так, как показано выше. Как я могу обновить свой код, чтобы правильно нарисовать квадрат?

Ответы [ 2 ]

0 голосов
/ 18 января 2019

Вы можете использовать двойной цикл for для печати 2D-массива. Просто посчитайте количество - в начале и в конце строки в зависимости от индекса.

public static void pattern(String str) {
    for (int i = 0, last = str.length() - 1; i <= last; i++) {
        for (int j = 0, dash = last; j <= last; j++, dash--)
            System.out.print(i < j && i > dash || i > j && i < dash ? '-' : str.charAt(i));

        System.out.println();
    }
}
0 голосов
/ 18 января 2019
static void pattern(String n) {
        int len = n.length();
for (int i = 0; i < len; i++) {
    for (int j = 0; j < len; j++) {
        if((i<j)&&(i>len-j-1) || (i>j)&&(i<len-j-1)) {
            System.out.printf("- ");

        } else  {
            System.out.printf("%c ", n.charAt(i));
        }
    }
    System.out.printf("%n");
}

Первое условие

 (i>j)&&(i<len-j-1)

выбирает следующую часть

x x x x x x x
- x x x x x x
- - x x x x x
- - - x x x x
- - x x x x x
- x x x x x x
x x x x x x x

и

 (i>j)&&(i<len-j-1)

выбирает следующие части

x x x x x x x
x x x x x x -
x x x x x - -
x x x x - - -
x x x x x - -
x x x x x x -
x x x x x x x
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...