Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
1 / 1 / 2
Регистрация: 28.11.2011
Сообщений: 49

Даны две строки, содержащие не более 100 символо

23.12.2011, 20:00. Показов 1608. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
6. Даны две строки, содержащие не более 100 символов. Строки состоят из слов, разделенных пробелами. Распечатать строку, которая содержит заданное слово заданное количество раз.
Вот код моей программы:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#include <iostream>
#include <conio.h>
#include <string.h>
#include <stdio.h>
#include <windows.h>
using namespace std;
int main()
{
    SetConsoleCP(1251);
 SetConsoleOutputCP(1251);
 char str1[101], str2[101], str3[20], slova[101][20], slova2[51][20];
        int z,k=0,i,j=0,v,kv=0;// j - номер очередного слова
    cout<<"Введите первую строку на латинской алфавите,состоящую из слов,разделённых пробелами (не более 100 символов):\n";
    gets(str1);
    cout<<"Введите вторую строку на латинской алфавите,состоящую из слов,разделённых пробелами (не более 100 символов):\n";
    gets(str2);
    cout<<"Введите искомое слово на латинской алфавите:\n";
    gets(str3);
    cout<<"Введите кол-во раз, которое введённое вами слово должно встречаться в строке:";
    cin>>z;
    for(i=0; i<strlen(str1);i++)
        if(str1[i]==' ')
        {
            strncpy(slova[j],str1+k,i-k);
            slova[j][i-k]=0;
        i++;
        k=i;
        j++;
        }
        strncpy(slova[j],str1+k,i-k);
            slova[j][i-k]=0;
            for(i=0;i<strlen(slova[j]);i++)
            {
            if(strcmp(slova[i],str3)==0);
            kv++;
            }
            if(z==kv)
            {
                cout<<"1-я строка содержит введённое слово заданное кол-во раз!\n";
                puts(str1);
            }
            else
                cout<<"1-я строка не содержит введённое слово заданное кол-во раз!\n";
            kv=0;
            k=0;
            j=0;
            for(i=0; i<strlen(str2);i++)
                if(str2[i]==' ')
                    {
                        strncpy(slova2[j],str2+k,i-k);
                        slova2[j][i-k]=0;
                        i++;
                        k=i;
                        j++;
                    }
                    strncpy(slova2[j],str2+k,i-k);
                    slova2[j][i-k]=0;
                    for(i=0;i<strlen(slova2[j]);i++)
                    {
                        if(strcmp(slova2[i],str3)==0); 
                            kv++;
                    }
                    if(z==kv)
                    {
                        cout<<"2-я строка содержит введённое слово заданное кол-во раз!\n";
                        puts(str2);
                    }
                    else
                        cout<<"2-я строка не содержит введённое слово заданное кол-во раз!\n";
                    getch();
}
Так вот.... почему-то переменную 'kv' прога плюсует больше раз,чем встречается введённое слово.... да и в массиве слов - после терминатора почему-то стоят строки из букв "М"(это я вижу,когда ставлю точки останова и просматриваю значения переменных)... и в вводимом слове - то же самое!!! Парни, помогите, пожалуйста.... может кто подскажет - в чём моя ошибка и поможет исправить её??? ПЛИЗ!!!!

Добавлено через 1 минуту
если я использую вместо функции strcmp функцию strstr - ничего не меняется в итоге.... прога так же работает неверно!!!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.12.2011, 20:00
Ответы с готовыми решениями:

Даны две строки, содержащие не более 100 символов.
Строки состоят из слов, разделенных пробелами. Распечатать все слова из каждой строки, начинающиеся и заканчивающие-ся на заданную...

Даны две строки, сформировать третью из символов, которые встречаются более двух раз
Добрый день, помогите с задачей пожалуйста:) Даны две строки, сформировать третью из символов , которые встречаются более двух раз. ...

Даны две переменные, в первой строка, во второй длина строки, 100 - max длина, строки. Что такое dup('$') ?
string db 100 stringlen db ?,100 dup('$')

2
2838 / 1647 / 254
Регистрация: 03.12.2007
Сообщений: 4,222
23.12.2011, 22:12
Юзай теги кода
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#include <iostream>
#include <conio.h>
#include <string.h>
#include <stdio.h>
#include <windows.h>
using namespace std;
int main()
{
SetConsoleCP(1251);
SetConsoleOutputCP(1251);
char str1[101], str2[101], str3[20], slova[101][20], slova2[51][20];
int z,k=0,i,j=0,v,kv=0;// j - номер очередного слова
cout<<"Введите первую строку на латинской алфавите,состоящую из слов,разделённых пробелами (не более 100 символов):\n";
gets(str1);
cout<<"Введите вторую строку на латинской алфавите,состоящую из слов,разделённых пробелами (не более 100 символов):\n";
gets(str2);
cout<<"Введите искомое слово на латинской алфавите:\n";
gets(str3);
cout<<"Введите кол-во раз, которое введённое вами слово должно встречаться в строке:";
cin>>z;
for(i=0; i<strlen(str1);i++)
if(str1[i]==' ')
{
strncpy(slova[j],str1+k,i-k);
slova[j][i-k]=0;
i++;
k=i;
j++;
}
strncpy(slova[j],str1+k,i-k);
slova[j][i-k]=0;
for(i=0;i<strlen(slova[j]);i++)
{
if(strcmp(slova[i],str3)==0);
kv++;
}
if(z==kv)
{
cout<<"1-я строка содержит введённое слово заданное кол-во раз!\n";
puts(str1);
}
else
cout<<"1-я строка не содержит введённое слово заданное кол-во раз!\n";
kv=0;
k=0;
j=0;
for(i=0; i<strlen(str2);i++)
if(str2[i]==' ')
{
strncpy(slova2[j],str2+k,i-k);
slova2[j][i-k]=0;
i++;
k=i;
j++;
}
strncpy(slova2[j],str2+k,i-k);
slova2[j][i-k]=0;
for(i=0;i<strlen(slova2[j]);i++)
{
if(strcmp(slova2[i],str3)==0);
kv++;
}
if(z==kv)
{
cout<<"2-я строка содержит введённое слово заданное кол-во раз!\n";
puts(str2);
}
else
cout<<"2-я строка не содержит введённое слово заданное кол-во раз!\n";
getch();
}

Строка 21. i <= strlen(str1), иначе последнее слово не сохранится, если после него нет пробела.
Строка 22. str1[i] == ' ' || str1[i] == 0 - по той же причине.
Строка 26. Не надо увеличивать, а то первая буква следующего слова пропускается.
Строка 27. Так как i++ убрали, тут тогда k = i + 1.
Строка 32. Длина слова-то при чём тут? Надо i < j.
Строка 34. Точка с запятой в конце строки не нужна.
И аналогично для второй строки. Неплохо бы это в отдельную функция вынести.
2
1 / 1 / 2
Регистрация: 28.11.2011
Сообщений: 49
23.12.2011, 22:24  [ТС]
Somebody, спасибо огромнейшее!!!!!!!!!!!!!!!!!!!!!! Оч помог!!!! СПААААААААСИИИИИИИИИБООООООО!!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.12.2011, 22:24
Помогаю со студенческими работами здесь

Пусть даны две очереди Х и У, содержащие вещественные числа
Сделать программу через процедуры Пусть даны две очереди Х и У, содержащие вещественные числа. Из каждой очереди одновременно извлекается...

Даны три множества X1,X2,X3, содержащие целые числа из диапазона 1...100.
Даны три множества X1,X2,X3, содержащие целые числа из диапазона 1...100. Известно, что мощность каждых из этих множеств равна 10....

Выделить из предложения слова, содержащие две или более одинаковые буквы
Строки (string) и использование библиотечных функций для их преобразования. Процедуры и функции Длина вводимого предложения не более 80...

Выделить из предложения слова, содержащие две или более одинаковые буквы
Задание: Выделить из предложения слова, содержащие две или более одинаковые буквы Описание задания: Введите с клавиатуры...

Выделить из предложения слова, содержащие две или более одинаковые буквы
Выделить из предложения слова, содержащие две или более одинаковые буквы. #include &lt;string.h&gt; #include &lt;stdio.h&gt; ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru