16 / 18 / 11
Регистрация: 07.03.2016
Сообщений: 362
|
|||||||||||
1 | |||||||||||
Почти одинаковые названия09.09.2017, 18:15. Показов 1203. Ответов 5
Метки нет (Все метки)
Я нахожусь в папке А1. У нее есть несколько дочерних папок. Например, Б1, Б2, Б3. В каждой из них либо лежат файлы, либо еще папки В1, В2, в которых уже лежат файлы. Моя программа идет по всем этим папкам и копирует оттуда файлы *.mp3 в папочку А2. Раньше я делал это рекурсией,
Вот так
, но потом мне объяснили, что это неправильно, и я стал делать Вот так
Еще в программе я запоминаю, какие файлы скопировал и если в какой-то папке встретил еще раз файл с таким же именем, не копирую его. Вопрос вот в чем. Может быть, например, такое, что в двух разных папках у одинаковых файлов различаются 1-3 символа или не хватает 1-3 символов в названии одного файла по сравнению с другим. Где стоят различающиеся или отсутствующие символы, я не знаю. Как сделать так, чтобы файлы, у которых разница с уже скопированным 3 или меньше символов тоже не копировались? Для простоты давайте считать, что различающиеся или отсутствующие символы могут стоять только в начале, но буду очень благодарен, если покажете, как отследить их в любом месте... Как различающиеся символы сделать я примерно представляю, но вот отсутствующие в середине названия...
0
|
09.09.2017, 18:15 | |
Ответы с готовыми решениями:
5
Почти одинаковые домены почти одинаковые элементы массива Почти одинаковые страницы с разными адресами Генерируются почти одинаковые случайные числа |
Супер-модератор
|
|
09.09.2017, 18:47 | 2 |
Сообщение было отмечено kolay_ne как решение
Решение
Я бы посчитал расстояние Левенштейна между этими названиями, оно как раз и выдаст количество различающихся/недостающих букв. Проверить онлайн, что будет выдано, перед тем, как начинать программировать вычисление дистанции, можно здесь
2
|
16 / 18 / 11
Регистрация: 07.03.2016
Сообщений: 362
|
|
09.09.2017, 19:43 [ТС] | 3 |
Как это сделать?Видимо, мне должна была помочь картинка, но я ее не понял... https://wikimedia.org/api/rest... d0183eec8c
0
|
Супер-модератор
|
||||||
09.09.2017, 20:41 | 4 | |||||
Сообщение было отмечено kolay_ne как решение
Решение
На картинке - не самый эффективный рекурсивный способ вычисления:
1
|
16 / 18 / 11
Регистрация: 07.03.2016
Сообщений: 362
|
||||||
09.09.2017, 22:55 [ТС] | 5 | |||||
volvo, Что-то не так. Вроде работает, но машина подсказывает непроходимые тесты:
volvo, Взял готовую реализацию с википедии. Она не шибко красивая, но норм работает. Завтра попробую покрасивее сделать путем перевода с python...
0
|
Супер-модератор
|
||||||
10.09.2017, 00:17 | 6 | |||||
Ну я же написал:
Значит, возьмем и сделаем его более эффективным (при помощи запоминания промежуточных результатов вместо их многократного пересчета - то есть, мемоизации). Итого имеем:
0
|
10.09.2017, 00:17 | |
10.09.2017, 00:17 | |
Помогаю со студенческими работами здесь
6
Как сократить почти одинаковые куски кода? Слить две почти одинаковые базы данных в одну Одинаковые названия функций QT и Socket Одинаковые названия id для 2х кнопок Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |