0 / 0 / 0
Регистрация: 21.09.2017
Сообщений: 8

Заменить слова в строке числами, соответствующими количеству входящих в них символов

06.10.2017, 13:56. Показов 932. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Само задание:
Ввести с клавиатуры символьную строку длиной не более 80 символов, рассматриваемую как произвольное абстрактное предложение, состоящее из слов. Слова отделяются друг от друга как минимум одним символом пробела. Строка должна быть введена посимвольно с использованием функции getchar(). Из нее построить новую строку, состоящую из цифр. Каждая цифра означает число различных (не повторяющихся) символов в соответствующем слове исходной строки.

Подскажите что не так, почему не работает?
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
#include "stdafx.h"
#define _CRT_SECURE_NO_WARNINGS
#pragma once
 
#include <iostream>
#include <conio.h>
#include <windows.h>
 
using namespace std;
 
void main(){
//русификация ввода/вывода
// установка кодовой страницы win-cp 1251 в поток ввода
SetConsoleCP(1251);
// установка кодовой страницы win-cp 1251 в поток вывода
SetConsoleOutputCP(1251);
 
    puts("Группа 6214\nМорозова Екатерина, вариант 16\nЛабораторная работа №1 - Язык С. Обработка строк");
    puts("Введите строку, используя русский и латинский алфавиты:");
    char *word, str[80];//Буфер для ввода строк и хранения слов
    char words[80]; //массив для хранения слов
    int n, count=0;
    for (n=0;n<80&&str[n-1]!='\n';n++) //Ввод первой строки
    {
        str[n]=getchar();
        str[n-1]='\0';
        word=(char*)malloc(sizeof(char)*81); //выделение памяти для найденных слов
        word=strtok(str," "); //Нахождение первого слова
        str[0]='\0';
        int b=0, s=0;
        while (word!=NULL)
        { //Нахождение последующих слов первой строки
            for (int i=0; i<strlen(word); i++)
            {
                char m=word[0];
                for (int i=0; i<strlen(word); i++)
                {
                    if (word[i]==m)
                    {
                        b++;
                    }
                }
                if (b==1)
                {
                    s++;
                }
                words[i]=(char)s;
            }
 
            word=strtok(NULL," ");
 
        }
    for (int i=0; i<strlen(word); i++)
    {
           strcat(str,words); //добавляем к ответу следующее число
            strcat(str," ");
    }
    puts(words);
    free(str);//освобождение памяти, выделенной на строки
    getch(); // Задержка окна консоли на экране перед завершением программы
    return;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.10.2017, 13:56
Ответы с готовыми решениями:

Во введенной строке символов найти пары, состоящие из одинаковых символов и заменить второй из них цифрой «1»
Во введенной строке символов найти пары, состоящие из одинаковых символов и заменить второй из них цифрой «1».

В введенной строке символов найти пары состоящие из одинаковых символов и заменить второй из них цифрой 1
В введенной строке символов найти пары состоящие из одинаковых символов и заменить второй из них цифрой 1

Заменить слова количеством символов в них
Дана строка, слова разделены пробелами или знаками препинаниния, заменить слова количеством символов в них.

1
738 / 543 / 416
Регистрация: 17.09.2015
Сообщений: 1,601
06.10.2017, 15:49
KaterinaMoro, уберите { из строки 24
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.10.2017, 15:49
Помогаю со студенческими работами здесь

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

Найти слова в исходной строке длиной не более 3-х символов и составить из них новую строку
найти слова в исходной строке длиной не более 3-х символов и составить из них новую строку, ввод строки с клавиатуры. ввод: abc qwer vbnm...

Найти слова в исходной строке длиной не более 3-х символов и составить из них новую строку
найти слова в исходной строке длиной не более 3-х символов и составить из них новую строку, ввод строки с клавиатуры.

Отсортировать предложения по количеству символов в них
В файле записан текст. Вывести предложения этого текста в порядке возрастания.

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru