Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.56/18: Рейтинг темы: голосов - 18, средняя оценка - 4.56
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6291 / 3015 / 1051
Регистрация: 01.06.2021
Сообщений: 11,412

Удаление повторяющейся части строки

01.08.2024, 21:38. Показов 4435. Ответов 54
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Хотел бы услышать различные мнения по вот такой задаче.

Нужно оставить в строке только уникальную начальную часть, а повторяющуюся хвостовую часть удалить.

Не то чтобы мне сложно самому написать код, но вот если у кого-нибудь есть хорошие идеи, как реализовать это очень эффективно, то прошу написать.

Примеры,

meowmeow → meow
meowme → meow
mmmmm → m
mmmmmr → mmmmmr
mmmmmrm → mmmmmr
kkkklsssskkkklsssskk → kkkklssss
kkkklsssskkkklssssskk → kkkklsssskkkklsssss
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.08.2024, 21:38
Ответы с готовыми решениями:

Удаление строк по повторяющейся ячейке
Есть 3 таблицы первая: Таблица 1: obj obj_id|owner_phone Таблица 2: obj_archive obj_id|owner_phone Таблица 2: obj_li ...

Удаление части строки
Доброго времени суток. Ломаю голову над проблемой второй день уже Есть конструкция типа <div...

Удаление части строки
В базе имеются такие строки 111.01 и 111.02.01 как обрезать строку, чтобы при выборке первый вариант (111.01) оставался...

54
 Аватар для analogov net
2532 / 1130 / 494
Регистрация: 17.11.2018
Сообщений: 2,838
04.08.2024, 19:25
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от Royal_X Посмотреть сообщение
я имел в виду string, как на входе, так и на выходе
Ну, ладно... так попробую:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
#include <string>
 
std::string find_pref(std::string& s, size_t j = 1, size_t i = 0) {
    if (j >= s.size()) {
        s.resize(j - i); 
        return s;
    }
    
    return find_pref(s, j + 1, (s[j] == s[i]) ? i + 1 : 0);
}
 
int main() {
    std::string str {"kkkklsssskkkklsssskk"};
 
    std::cout << find_pref(str) << std::endl;   // "kkkklssss"
}
1
фрилансер
 Аватар для Алексей1153
6495 / 5723 / 1133
Регистрация: 11.10.2019
Сообщений: 15,283
04.08.2024, 19:26
Цитата Сообщение от Royal_X Посмотреть сообщение
и конечно же ты не станешь здесь писать, что именно
как скажешь
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6291 / 3015 / 1051
Регистрация: 01.06.2021
Сообщений: 11,412
04.08.2024, 19:29  [ТС]
Алексей1153, если у функции будут другие типы, то придется заняться преобразованиями.
входная строка это const string и не в моей власти менять остальной код. Поэтому я предлагаю именно участникам соревнования сразу учесть данный фактор
0
фрилансер
 Аватар для Алексей1153
6495 / 5723 / 1133
Регистрация: 11.10.2019
Сообщений: 15,283
04.08.2024, 19:36
Royal_X, std::string_view как раз предназначен для того, чтобы принимать char*, std::string или std::string_view, а не писать три перегрузки функции
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6291 / 3015 / 1051
Регистрация: 01.06.2021
Сообщений: 11,412
04.08.2024, 19:45  [ТС]
Цитата Сообщение от analogov net Посмотреть сообщение
Ну, ладно... так попробую:
так уже норм, но работает неправильно

Добавлено через 7 минут
Цитата Сообщение от Алексей1153 Посмотреть сообщение
std::string_view как раз предназначен для того
повышать код до С++17 не хочу и конечный результат мне нужен в string
я согласен, std::string -> std::string_view преобразовывается без копирования
а вот с std::string_view -> std::string уже печалька
0
 Аватар для analogov net
2532 / 1130 / 494
Регистрация: 17.11.2018
Сообщений: 2,838
04.08.2024, 19:47
Цитата Сообщение от Royal_X Посмотреть сообщение
но работает неправильно
не верный результат или что-то другое?
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6291 / 3015 / 1051
Регистрация: 01.06.2021
Сообщений: 11,412
04.08.2024, 19:48  [ТС]
Цитата Сообщение от analogov net Посмотреть сообщение
не верный результат или что-то другое?
первое

такие же проблемы, что были сперва у nalbe666, но он их потом исправил и довел код до рабочего состояния


Например, у тебя

ddcdcdaccbcdcddbabdcbdcdddbccadacabddddcabcbcaadcadcdbbbaaabdabbabaccaccbcdaadccbbdadbacdcabbaadcddcdccccababddaddcbaabaadddcdc

так и остается, тогда как правильно будет

ddcdcdaccbcdcddbabdcbdcdddbccadacabddddcabcbcaadcadcdbbbaaabdabbabaccaccbcdaadccbbdadbacdcabbaadcddcdccccababddaddcbaabaad
0
 Аватар для analogov net
2532 / 1130 / 494
Регистрация: 17.11.2018
Сообщений: 2,838
04.08.2024, 19:53
Лучший ответ Сообщение было отмечено Royal_X как решение

Решение

Цитата Сообщение от Royal_X Посмотреть сообщение
первое
а так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
#include <string>
 
std::string find_pref(const std::string & s, size_t j = 1, size_t i = 0) {
    if (j >= s.size()) 
        return s.substr(0, j - i);
 
    return (s[j] == s[i]) ? find_pref(s, j + 1, i + 1) : find_pref(s, j - i + 1);
}
 
int main() {
    std::string str {"kkkklsssskkkklsssskk"};
 
    std::cout << find_pref(str) << std::endl;   // "kkkklssss"
}
2
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6291 / 3015 / 1051
Регистрация: 01.06.2021
Сообщений: 11,412
04.08.2024, 19:57  [ТС]
Цитата Сообщение от analogov net Посмотреть сообщение
а так:
так уже правильно, но код хоть и очень быстрый, но в два раза медленнее, чем у nalbe666. А вот твой первый неправильный вариант имел такую же скорость.
0
 Аватар для analogov net
2532 / 1130 / 494
Регистрация: 17.11.2018
Сообщений: 2,838
04.08.2024, 19:59
может быть потому что это рекурсия?
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6291 / 3015 / 1051
Регистрация: 01.06.2021
Сообщений: 11,412
04.08.2024, 20:03  [ТС]
Цитата Сообщение от analogov net Посмотреть сообщение
может быть потому что это рекурсия?
код до исправления был дважды быстрее, хотя тоже рекурсия

в любом случае, твой вариант тоже выделил как ответ, пусть будет несколько ответов

и Алексей1153 вроде же говорит, что оптимизатор так не оставит
0
фрилансер
 Аватар для Алексей1153
6495 / 5723 / 1133
Регистрация: 11.10.2019
Сообщений: 15,283
04.08.2024, 20:07
Royal_X, в посте 48 - НЕ хвостовая рекурсия, так что там, видимо, будут честные вызовы
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6291 / 3015 / 1051
Регистрация: 01.06.2021
Сообщений: 11,412
04.08.2024, 20:09  [ТС]
Алексей1153, ясно, но я в этом не разбираюсь
0
 Аватар для Наталья8
623 / 381 / 67
Регистрация: 09.03.2016
Сообщений: 4,211
04.08.2024, 23:30
Мутная какая то хрень. Неоднозначная.
"mmmmmmmmmm" - одно слово?
А почему оно не два одинаковых?
0
 Аватар для analogov net
2532 / 1130 / 494
Регистрация: 17.11.2018
Сообщений: 2,838
15.08.2024, 20:22
Цитата Сообщение от analogov net Посмотреть сообщение
хотя, можно и не рекурсивную написать...
например:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
#include <string>
 
std::string find_pref( const std::string &s ){
    size_t n = s.size(), i = 0, j = 0;
 
    while( ++j < n )
        if( s[j] == s[i] )    i++;
        else                  j -= i, i = 0;
 
    return s.substr( 0, j - i );
}
 
int main(){
    std::cout << find_pref( "kkkklsssskkkklsssskk" ) << std::endl;  // kkkklssss
    std::cout << find_pref( "565656565" ) << std::endl;             // 56
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.08.2024, 20:22

Удаление части строки
В string у меня есть несколько символов. Мне необходимо удалить из строки определённый символ (позицию которого в строке я не знаю). Как я...

Удаление части строки
Добрый день. Нужна помощь. Дана строка типа &quot;C:\Program Files\Java\PHP\delete.txt&quot; (Директория может быть любой). Нужно удалить конец...

Удаление части строки
Дана строка. Из другой строки в текстовом файле надо удалить из строки эту указанную строку. Помогите реализовать. Я высчитал формулу,чтобы...

удаление части строки
Всем привет! Есть вопрос. У меня есть бинарный файл. В нем содержится информация: Идентификатор Фамилия Имя Отчество. А именно: 1 Иванов...

Удаление части строки
Имеется переменная, содержащая имя файла, например, $var = &quot;filename.txt&quot; Надо что-то сделать, чтоб чтоб осталось только...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
55
Ответ Создать тему
Новые блоги и статьи
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики Контекст Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии Введение Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np class PlantAgent: def __init__(self, name, strategy, initial_biomass): self. name = name self. strategy = strategy # "greedy" (широколиственные) или. . .
сукцессия 9. Математика подлости: как растения предали грибных друзей
anaschu 27.06.2026
Статья 2. Глобальная фосфорная война: эволюционно-экономические механизмы распределения биомов Земли Введение: Экологический рынок как игра с нулевой суммой Традиционная экология долгое время. . .
сукцессия 8. Как я спорил с ИИ, которые - агенты растений и ненавистники грибов!
anaschu 27.06.2026
Статья 1. Хроники грибного восстания: как Сократов диалог разрушил академические догмы ИИ Введение: Синдром «цифрового учебника» Современные большие языковые модели (LLM) обладают колоссальным. . .
Главный вопрос моделирования сукцессии
anaschu 27.06.2026
главный вопрос. Если эктомикориза лучше добывает недоступный фосфор. И ее масса максимальна из всех. А широколиственный лес тоже имеет самую крутую биомассу. То почему не возникло их симбиоза? Это. . .
сукцессия 6. Питон реализация энилоджиковской модели, картинка про Центральную часть будущей модели
anaschu 26.06.2026
Етить. ИИ мне на основе моего старого файла R создал вот эту вот хмерь на пайтоне. Это уже новая модель, модель сукцессии грибной. потоки фосфора, азота. Углерода. 5 видов организмов. Я даже. . .
Как замкнутый ядерный цикл решит проблему недостатки фосфора? Био миграция фосфора со дна океана
anaschu 26.06.2026
Биологический лифт: Концепция подъема фосфора со дна океана с помощью ЗЯТЦ Предлагаю на обсуждение альтернативу тяжелому промышленному бурению океанического дна. Вместо сложной инженерии мы можем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru