Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.78/40: Рейтинг темы: голосов - 40, средняя оценка - 4.78
 Аватар для Alisia
0 / 0 / 0
Регистрация: 05.11.2011
Сообщений: 23

Задачка на строки

07.11.2011, 17:28. Показов 8750. Ответов 24
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите кто может, пожалуйста.
Задана строка S. Найдите количество ее различных подстрок, включая пустую. Буквы подстроки могут идти не подряд в самой строке.

Ввод
В первой строке записана строка S (длина от 1 до 25).

Вывод
Выведите ответ.

Пример:

Ввод
AAC

Вывод
6
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.11.2011, 17:28
Ответы с готовыми решениями:

задачка на строки
задана строка символов Определить ,встречается ли в ней заданное с клавиатуры слово.Если такое слово встречается в строке.то необходимо...

задачка на строки
у кого какие мысли по этой задачке поделитесь Дана строка s, содержащая от 1 до 30 слов, в каждом из которых от 1 до 5 строчных...

задачка на строки
Ребят помогите решить след. задачу: Во введённом тексте заменить цифры от 0 до 9 на слова «ноль, «один», …, «девять». её нужно...

24
07.11.2011, 17:47

Не по теме:

Цитата Сообщение от Alisia Посмотреть сообщение
Найдите количество ее различных подстрок, включая пустую. Буквы подстроки могут идти не подряд в самой строке.
- в смыле подстроки AAC это :
AAC

AA
А
А
С - таков алгоритм выделения подстрок?

0
 Аватар для Alisia
0 / 0 / 0
Регистрация: 05.11.2011
Сообщений: 23
07.11.2011, 19:57  [ТС]
Цитата Сообщение от -=ЮрА=- Посмотреть сообщение

Не по теме:

- в смыле подстроки AAC это :
AAC

AA
А
А
С - таков алгоритм выделения подстрок?

Количество подстрок заканчивающиеся на а: а, аа - 2
заканчивающиеся на с: с, ас, аас - 3
=> 3 + 2 + пустая = 6

Добавлено через 2 часа 6 минут
пустая так же всегда считается
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
07.11.2011, 20:02
Цитата Сообщение от Alisia Посмотреть сообщение
Количество подстрок заканчивающиеся на а: а, аа - 2
заканчивающиеся на с: с, ас, аас - 3
=> 3 + 2 + пустая = 6
зачем путаете людей и причем тут буква, на которую заканчиваются подстроки. -=ЮрА=-, вы правильно мыслите:
AAC
AA
AC
A
C
пустая подстрока,
то есть всего 6 штук.
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
07.11.2011, 20:31
Alisia, С/С++ string можно использовать???
0
 Аватар для Alisia
0 / 0 / 0
Регистрация: 05.11.2011
Сообщений: 23
07.11.2011, 20:37  [ТС]
Цитата Сообщение от -=ЮрА=- Посмотреть сообщение
Alisia, С/С++ string можно использовать???
нужно же. разве нет?
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
07.11.2011, 20:41
Предлагаю пока вариант без всяких библиотек на Си
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <stdio.h>
#include <conio.h>
 
int main()
{
    long i,sLen;
    char str[1024] = {0};
    printf("Enter string\n");
    scanf("%[^\n]",str);
    printf("SubStrings\n");
    for(sLen = 0; str[sLen] !='\0'; sLen++)
        printf("%s\n",str + sLen);
    for(i = sLen - 1; 0 <= i; i--)
    {
        str[i] = '\0';//режем строку от конца
        printf("%s\n",str);
    }
    printf("Press any key to continue\n");
    getch();
    return 0;
}
Миниатюры
Задачка на строки  
1
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
07.11.2011, 20:48
Вот со string-ами на плюсах
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <iostream>
#include <string>
using namespace std;
 
int main()
{
    long i,sLen;
    string str;
    cout<<"Enter string\n";
    getline(cin,str);
    sLen = str.length();
    cout<<"SubStrings\n";
    for(i = 0; i < sLen; i++)
        cout<<str.substr(i,str.length() - i).c_str()<<endl;
    for(i = 0; i < sLen; i++)
    {   
        str.erase(str.length() - 1);
        cout<<str.c_str()<<endl;
    }
    system("pause");
    return 0;
}
Миниатюры
Задачка на строки  
1
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
07.11.2011, 20:51

Не по теме:

Цитата Сообщение от Alisia Посмотреть сообщение
нужно же. разве нет?
- предположу что вам плюсы преподают так вот кроме string ещё существуют char * string, CString s , я ж не знаю в чём вам вот и спрашивал...



Добавлено через 41 секунду
Alisia, ауу вы здесь вообще?
0
 Аватар для Alisia
0 / 0 / 0
Регистрация: 05.11.2011
Сообщений: 23
07.11.2011, 20:51  [ТС]
Цитата Сообщение от -=ЮрА=- Посмотреть сообщение

Не по теме:

- предположу что вам плюсы преподают так вот кроме string ещё существуют char * string, CString s , я ж не знаю в чём вам вот и спрашивал...

спасибо, но мне нужно не все подстроки найти, а всего лишь их кол-во
0
5 / 5 / 2
Регистрация: 21.03.2011
Сообщений: 79
07.11.2011, 20:53
))) наверное плюсы
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
07.11.2011, 20:54
Подозрваю, что ввод банального счётчика подстрок вызовет сложности поэтому вот код на плюсах со счётчиком
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <string>
using namespace std;
 
int main()
{
    long i,sLen, n = 0;
    string str;
    cout<<"Enter string\n";
    getline(cin,str);
    sLen = str.length();
    cout<<"SubStrings\n";
    for(i = 0; i < sLen; i++, n++)
        cout<<str.substr(i,str.length() - i).c_str()<<endl;
    for(i = 0; i < sLen; i++, n++)
    {   
        str.erase(str.length() - 1);
        cout<<str.c_str()<<endl;
    }
    cout<<"Count of SubStrings : "<<n<<endl;
    system("pause");
    return 0;
}
PS:После ввода строки на старых компиляторах Enter нужно жать 2 раза, такой уж прикол со стринг на старье
Миниатюры
Задачка на строки  
1
 Аватар для Alisia
0 / 0 / 0
Регистрация: 05.11.2011
Сообщений: 23
07.11.2011, 20:55  [ТС]
Цитата Сообщение от -=ЮрА=- Посмотреть сообщение

Не по теме:

- предположу что вам плюсы преподают так вот кроме string ещё существуют char * string, CString s , я ж не знаю в чём вам вот и спрашивал...



Добавлено через 41 секунду
Alisia, ауу вы здесь вообще?
с++, я думала на Си сейчас уже не пишут
0
07.11.2011, 20:57

Не по теме:

Цитата Сообщение от Alisia Посмотреть сообщение
я думала на Си сейчас уже не пишут
- значит я последний из могикан:D
PS:Вы код из поста 12 смотрели???

1
 Аватар для Alisia
0 / 0 / 0
Регистрация: 05.11.2011
Сообщений: 23
07.11.2011, 21:03  [ТС]
Цитата Сообщение от -=ЮрА=- Посмотреть сообщение

Не по теме:

- значит я последний из могикан:D
PS:Вы код из поста 12 смотрели???

да смотрела. мне просто кол-во всех возможных подстрок надо. без их вывода на экран

Добавлено через 2 минуты
и для 'abc' например, ответ уже будет 8, а у вас 6
0
07.11.2011, 21:05

Не по теме:

Цитата Сообщение от Alisia Посмотреть сообщение
да смотрела. мне просто кол-во всех возможных подстрок надо. без их вывода на экран
- млин у вас вобще что ли рук нет закоментить ненужный вывод???:cry:
Всё ввиду полного отсутсвия наличия хоть намёка на логику покинул топик...

0
 Аватар для Alisia
0 / 0 / 0
Регистрация: 05.11.2011
Сообщений: 23
07.11.2011, 21:06  [ТС]
Цитата Сообщение от -=ЮрА=- Посмотреть сообщение

Не по теме:

- млин у вас вобще что ли рук нет закоментить ненужный вывод???:cry:
Всё ввиду полного отсутсвия наличия хоть намёка на логику покинул топик...

не волнуйтесь так, все я делала)) дело в том, что результат не верный) для abc должен быть ответ 8, а не 6
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
07.11.2011, 21:07
Цитата Сообщение от Alisia Посмотреть сообщение
и для 'abc' например, ответ уже будет 8, а у вас 6
- Вот поэтому и нужно такие алгоритмы снабжать выводом подстрок
Миниатюры
Задачка на строки  
0
07.11.2011, 21:09

Не по теме:

Цитата Сообщение от Alisia Посмотреть сообщение
не волнуйтесь так, все я делала)) дело в том, что результат не верный) для abc должен быть ответ 8, а не 6
- вот именно что ничего вы не делали, как результат скрин ввирху, а просто копипастили даже не думая об алгоритмической стороне, в последнее время выносит мозг от такого....

0
 Аватар для Alisia
0 / 0 / 0
Регистрация: 05.11.2011
Сообщений: 23
08.11.2011, 18:48  [ТС]
А как эту задачку можно через динамику решить?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.11.2011, 18:48
Помогаю со студенческими работами здесь

Задачка на строки
'Необходимо определить число входящих в строку цифр' Что то даже мыслей нет помогите пожалуйста с кодом

Еще задачка на строки
подсчитать сколько раз определенный символ х встречается в строке

Инициализация строки - задачка
Сама задачка от Kastaneda: #include &lt;string&gt; #include &lt;iostream&gt; using namespace std; #define DEBUG( str ) do{ cout &lt;&lt;...

Задачка про строки и слова
Ошибочка закралась: суть задачки надо прочитать файл и вывести слова которые начинаются и кончаются на &quot;a&quot; (ну вот вбил я в свой...

Простая задачка: Распаковка строки
Задача D «Распаковка строчки» Будем рассматривать только строчки, состоящие из заглавных латинских букв. Например, рассмотрим...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru