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

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

07.11.2011, 17:28. Показов 8758. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru