169 похожих чатов

Доброго времени суток, скажите кто-нибудь сталкивался с задачей генерации имён

с добавлением цифры в конце ? Т.е. есть массив имён [тест, тест 1, тест 2] и нам нужно чтобы следующее имя соответственно было тест 3
Но (как жее без но)
Нужно чтобы нумерация могла задаваться с произвольного числа, пропускаться для первого элемента, массив может содержать разные имена (для этого мы подаем то имя для которого нужно продолжить ряд) и при этом массив можеет содержать не упорядоченные значения в виде [тест 10, тест, тест 2] и в итоге вернуть тест 11 (например)
А то я что-то голову сломал, вродё всё ок, но вот последнее условие не понинмаю как обработать

12 ответов

22 просмотра

Я правильно понимаю что цифра на конце поданного имени будет обязательно больше тех что уже есть в таких же именах?

Maxim-Stogniy Автор вопроса
Maxim Stogniy
Верно, следующая за максимальным

Тогда фильтруешь массив по содержанию подстроки с именем, потом находишь в результате элемент с максимальным числом (возможны варианты), потом паришь это число и добавляешь куда тебе надо имя + увеличенное число.

Maxim-Stogniy Автор вопроса

Видел как подобная задача была решена через рекурсию. Например, в функцию передаётся текст "name5". Функция проверяет массив. Если такое имя уже занято, то имя меняется на "name6" и с этим значением функция вызывает сама себя. Так продолжается, пока на найдётся имя, которого нет в массиве. Тогда оно добавляется в массив и возвращается как результат.

Пока обед решил тоже попробовать. ))) const namesList = ["тест10", "тест", "тест2", "бро12", "валенок5", "тест11", "сосед38"]; function namesNew(word) { const filtered = namesList.filter((it) => it.startsWith(word)).sort((a, b) => a.localeCompare(b, ["ru", "en-US"], {numeric: true})), length = filtered.length; if (length) { const max = filtered[length - 1], number = max ? max.match(/(\d+)$/g) : null; if (number && number.length && Number.isFinite(+number)) { namesList.push(word + (+number + 1)); } else { namesList.push(word); } } else { namesList.push(word); } } namesNew("тест");

Почему не доверяешь? ))

Что значит пропустить нумерацию для первого или начать с заданной цифры?

Maxim-Stogniy Автор вопроса
Макс Ворон
Почему не доверяешь? ))

А это мой косяк, я что-то не знал про сортировку с numeric: true

Maxim-Stogniy Автор вопроса
Макс Ворон
Что значит пропустить нумерацию для первого или на...

Ну вот есть у тебя список например ["бро12", "валенок5"] или пустой массив И тебе нужно сгенерировать последовательно для тест, но чтобы первый элемент был без номера либо наоборотт с заданным номером т.е. test, test1, test2 или test1, test2, test3 если с 2ки

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта