Палиндром: поиск кратчайшей строки - PullRequest
0 голосов
/ 27 февраля 2019

Задача состоит в следующем: «Напишите программу на JavaScript, чтобы найти самую короткую из возможных строк, которая может создать строку, превращающую ее в палиндром, путем добавления символов в конце».

Это кодЯ смотрю на:

function build_Palindrome(new_str) {
  var flag;
  for (var i = new_str.length;; i++) {
    flag = true;
    for (var j = 0; j < i - j - 1; j++) {
      if (i - j - 1 < new_str.length && new_str[j] != new_str[i - j - 1]) {
        flag = false;
        break;
      }
    }
    if (flag) {
      for (var j = new_str.length; j < i; j++) {
        new_str += new_str[i - j - 1];
      }
      return new_str;
    }
  }
}

Тест:

console.log(build_Palindrome("abcddc"))

Вывод:

abcddcba    

Мой вопрос: Сначала он начинается с j=0.Если в цикле for, flag=false, как это происходит?Это i=7 (i++?) И j=0 или j=1?

1 Ответ

0 голосов
/ 27 февраля 2019

Да, вы можете использовать console.log или любой отладчик для отладки.

В вашей ситуации, если флаг имеет значение false, он разорвет цикл j и перейдет к внешнему циклу ( i здесь)

Я сделал демо здесь: https://repl.it/repls/LoyalProfuseRouter

Вы можете увидеть демо (оно поставляется с моим решением), и вместо разрыва вы можете использовать простой цикл для возврата вашей строки,это более читабельно.

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