кодесурса
«JavaScript

JavaScript: найти самую длинную подстроку в данной строке без повторяющихся символов

script1adsense2code
script1adsense3code

Функция JavaScript: упражнение 26 с решением

Напишите функцию JavaScript, чтобы найти самую длинную подстроку в данной строке без повторяющихся символов.

Пример решения : -

HTML-код:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Find longest substring in a given a string without repeating characters</title>
</head>
<body>
</body>
</html>

Код JavaScript:

function longest_substring_without_repeating_characters(input) {
var chars = input.split('');
var curr_char;
var str = "";
var longest_string = "";
var hash = {};
for (var i = 0; i < chars.length; i++) {
curr_char = chars[i];
if (!hash[chars[i]]) 
{ 
str += curr_char; 
hash[chars[i]] = {index:i};
}
else 
{
if(longest_string.length <= str.length)
{
longest_string = str;
}
var prev_dupeIndex = hash[curr_char].index;
var str_FromPrevDupe = input.substring(prev_dupeIndex + 1, i);
str = str_FromPrevDupe + curr_char;
hash = {};
for (var j = prev_dupeIndex + 1; j <= i; j++) {
hash[input.charAt(j)] = {index:j};
}
}
}
return longest_string.length > str.length ? longest_string : str;
}
console.log(longest_substring_without_repeating_characters("google.com")); 
console.log(longest_substring_without_repeating_characters("example.com")); 

Выход:

 gle.com
xample.co

Блок - схема:

«Блок-схема:

Демонстрация в реальном времени:

См. Pen JavaScript - Найти самую длинную подстроку в данной строке без повторения символов-function-ex- 26 от w3resource ( @ w3resource ) в CodePen .


Улучшите этот пример решения и опубликуйте свой код через Disqus

Previous: написать функцию JavaScript, которая принимает список названий стран в качестве входных данных и возвращает самое длинное название страны в качестве выходных
Далее: Напишите функцию JavaScript, которая возвращает самый длинный палиндром в данной строке.

Каков уровень сложности этого упражнения?

Новый контент: Composer: менеджер зависимостей для PHP , R программирования


script1adsense4code
script1adsense5code
disqus2code
script1adsense6code
script1adsense7code
script1adsense8code
buysellads2code