Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 8
Builder 6

Анализ вхождения слов в файл

19.06.2019, 16:36. Показов 1638. Ответов 13

Студворк — интернет-сервис помощи студентам
Ребят,срочно нужна помощь. Не могу написать код который будет анализировать текстовый файл и выводить количество вхождений каждого слова.
Я пробовал что-то накатать но ничего не выходит.
Вот мои попытки
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
#include <vcl.h>
#pragma hdrstop
#include <iostream.h>
#include <string.h>
#include <map.h>
 
#pragma argsused
 
using namespace std;
 
typedef map<string, int> CountMap;
 
void PushWords(CountMap& list, const char* words)
{
    char ch = '\0';
    unsigned int len = strlen(words);
    string str;
    int index = 0;
    for (unsigned int i = 0; i < len; i++)
    {
        ch = words[i];
        if (index > 0 && ch == ' ')
        {
            list[str] = list[str] + 1;
            index = 0;
        }
        else if (ch != ' ')
        {
            str += ch;
            index++;
        }
    }
 
    if (index > 0 && ch == ' ')
    {
        list[str] = list[str] + 1;
    }
}
 
void PrintCount(CountMap& list)
{
    CountMap::iterator iter = list.begin(), end = list.end();
    for (; iter != end; ++iter)
    {
        cout << (*iter).first << " : " << (*iter).second;
    }
}
 
int main()
{
    CountMap map;
    PushWords(map, "Hello world this is a hello world test bla");
    PrintCount(map);
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.06.2019, 16:36
Ответы с готовыми решениями:

Файл: Провести анализ вхождения букв начала алфавита А, Б, В, Г.
Провести анализ вхождения букв начала алфавита А, Б, В, Г. То есть определить отношение появления этих букв ко всем буквам текста....

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

Вывести заданную последовательность слов, но удалив из неё повторные вхождения слов
Дана последовательность, содержащая от 1 до 30 слов, в каждом из которых от 1 до 5 строчных латинских букв; между соседними словами –...

13
Модератор
 Аватар для D1973
9929 / 6467 / 2457
Регистрация: 21.01.2014
Сообщений: 27,423
Записей в блоге: 3
19.06.2019, 17:17
tearonbits, Вам принципиально использовать С-шные методы? Методы С++ Builder Вас не устраивают? Тем более, в задании Вы говорите про текстовый файл, а в коде анализируете просто строку...
0
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 8
19.06.2019, 18:06  [ТС]
Буду очень рад если поможешь

Добавлено через 2 минуты
На деле именно Билдер и нужен. Я просто в этом вообще ничего не понимаю
0
Модератор
 Аватар для D1973
9929 / 6467 / 2457
Регистрация: 21.01.2014
Сообщений: 27,423
Записей в блоге: 3
20.06.2019, 06:13
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <memory>
...
void __fastcall TForm1::Button1Click(TObject *Sender)
{
   std::auto_ptr<TStringList> L (new TStringList);
   L->LoadFromFile("C:\\TMP\\111.txt"); //тут укажете свой файл с текстом.
   Memo1->Lines->Assign(L.get());
   L->CommaText = StringReplace(L->Text, "\r\n", " ", TReplaceFlags() << rfReplaceAll);
   L->Sort();
   Memo2->Clear();
   std::auto_ptr<TStringList> tmp (new TStringList);
   for(int i = 0; i < L->Count; i++)
     {
       int k = tmp->IndexOf(L->Strings[i]);
       if(k == -1) tmp->AddObject(L->Strings[i], (TObject*)1);
       else tmp->Objects[k] = (TObject*)(((int)tmp->Objects[k] + 1));
     }
   for(int i = 0; i < tmp->Count; i++)
     Memo2->Lines->Add(String().sprintf("%s - %d", tmp->Strings[i], (int)tmp->Objects[i]));
}
А вот тут есть более изящное решение с использованием класса-наследника от TStringList
Миниатюры
Анализ вхождения слов в файл  
2
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 8
20.06.2019, 09:10  [ТС]
Кинуло в почти 500 строк конфига и выдаёт ошибки в строках
namespace std { }
namespace __std_alias = std;
0
Модератор
 Аватар для D1973
9929 / 6467 / 2457
Регистрация: 21.01.2014
Сообщений: 27,423
Записей в блоге: 3
20.06.2019, 09:20
tearonbits, значит - не судьба...
1
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 8
20.06.2019, 09:35  [ТС]
Всё равно спасибо большое
0
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 8
20.06.2019, 09:43  [ТС]
Помогите,не пойму куда пихать код.Он вроде и рабочий но кидает в 500 строк конфига с ошибкой в строках
C++
1
2
namespace std { }
namespace __std_alias = std;
вот сам код програмы
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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
 
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
 
void __fastcall TForm1::FormCreate(TObject *Sender)
{
#include <memory>
...
void __fastcall TForm1::Button1Click(TObject *Sender)
{
   std::auto_ptr<TStringList> L (new TStringList);
   L->LoadFromFile("C:\\TMP\\111.txt"); //тут укажете свой файл с текстом.
   Memo1->Lines->Assign(L.get());
   L->CommaText = StringReplace(L->Text, "\r\n", " ", TReplaceFlags() << rfReplaceAll);
   L->Sort();
   Memo2->Clear();
   std::auto_ptr<TStringList> tmp (new TStringList);
   for(int i = 0; i < L->Count; i++)
     {
       int k = tmp->IndexOf(L->Strings[i]);
       if(k == -1) tmp->AddObject(L->Strings[i], (TObject*)1);
       else tmp->Objects[k] = (TObject*)(((int)tmp->Objects[k] + 1));
     }
   for(int i = 0; i < tmp->Count; i++)
     Memo2->Lines->Add(String().sprintf("%s - %d", tmp->Strings[i], (int)tmp->Objects[i]));
}
}
//---------------------------------------------------------------------------
0
 Аватар для TrollHammer
1216 / 709 / 336
Регистрация: 22.02.2018
Сообщений: 2,095
Записей в блоге: 2
20.06.2019, 09:55
tearonbits, Где он рабочий?

Добавлено через 1 минуту
Вот так:
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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#include <memory>
#pragma hdrstop
 
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
 
void __fastcall TForm1::Button1Click(TObject *Sender)
{
   std::auto_ptr<TStringList> L (new TStringList);
   L->LoadFromFile("C:\\TMP\\111.txt"); //тут укажете свой файл с текстом.
   Memo1->Lines->Assign(L.get());
   L->CommaText = StringReplace(L->Text, "\r\n", " ", TReplaceFlags() << rfReplaceAll);
   L->Sort();
   Memo2->Clear();
   std::auto_ptr<TStringList> tmp (new TStringList);
   for(int i = 0; i < L->Count; i++)
     {
       int k = tmp->IndexOf(L->Strings[i]);
       if(k == -1) tmp->AddObject(L->Strings[i], (TObject*)1);
       else tmp->Objects[k] = (TObject*)(((int)tmp->Objects[k] + 1));
     }
   for(int i = 0; i < tmp->Count; i++)
     Memo2->Lines->Add(String().sprintf("%s - %d", tmp->Strings[i], (int)tmp->Objects[i]));
}
 
//---------------------------------------------------------------------------
При этом на форме должны быть 2 Memo и 1 Button, у которого должен быть определен вышеуказанный обработчик нажатия Button1Click

Добавлено через 2 минуты
tearonbits, Я так понимаю, что Builder вы в первый раз увидели?
0
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 8
20.06.2019, 09:57  [ТС]
В один из первых раз.У меня этим проблемы но это мне нужно.
Ещё кидает ошибку в 20 строке на скобке.
[C++ Error] Unit1.cpp(20): E2316 '_fastcall TForm1::Button1Click(TObject *)' is not a member of 'TForm1'
0
 Аватар для TrollHammer
1216 / 709 / 336
Регистрация: 22.02.2018
Сообщений: 2,095
Записей в блоге: 2
20.06.2019, 10:05
Цитата Сообщение от tearonbits Посмотреть сообщение
[C++ Error] Unit1.cpp(20): E2316 '_fastcall TForm1::Button1Click(TObject *)' is not a member of 'TForm1'
Ясен пень, он у Вас не определен. Даю пошаговую инструкцию:
1. Создаем новый проект
2. Кидаем на форму 2 Memo и 1 Button
3. Дважды щелкаем на Button - появится пустой обработчик
4. Туда кидаем этот код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
std::auto_ptr<TStringList> L (new TStringList);
   L->LoadFromFile("C:\\TMP\\111.txt"); //тут укажете свой файл с текстом.
   Memo1->Lines->Assign(L.get());
   L->CommaText = StringReplace(L->Text, "\r\n", " ", TReplaceFlags() << rfReplaceAll);
   L->Sort();
   Memo2->Clear();
   std::auto_ptr<TStringList> tmp (new TStringList);
   for(int i = 0; i < L->Count; i++)
     {
       int k = tmp->IndexOf(L->Strings[i]);
       if(k == -1) tmp->AddObject(L->Strings[i], (TObject*)1);
       else tmp->Objects[k] = (TObject*)(((int)tmp->Objects[k] + 1));
     }
   for(int i = 0; i < tmp->Count; i++)
     Memo2->Lines->Add(String().sprintf("%s - %d", tmp->Strings[i], (int)tmp->Objects[i]));
5. ВВерху под #include <vcl.h> добавляем #include <memory>
6. Сохраняем
7. Делаем Project->Build
8. Run
9. Все работает

ДА! и не забываем положить в c:\tmp файлик 1111.txt с текстом

Добавлено через 3 минуты
Цитата Сообщение от tearonbits Посмотреть сообщение
В один из первых раз
Так найдите в сети книжку Архангельского "Программирование в C++ Builder 6", там описано все, куча примеров и справочного материала.
"Прежде чем писать программы, умоляю Вас, прочитайте инструкцию к Вашему компилятору"(С) Андрэ Ламот
2
Модератор
 Аватар для D1973
9929 / 6467 / 2457
Регистрация: 21.01.2014
Сообщений: 27,423
Записей в блоге: 3
20.06.2019, 10:36
tearonbits, вот неужели это надо объяснять, что никто, кроме Вас, Ваш проект не видит, что Вы там наделали кроме того, что Вам было написано - неизвестно. Так же, как не известен точный текст ошибки. Скидывайте архив проекта, только без мусора, только файлы *.bpr, *.cpp, *.h, *.dfm. Тогда это будет предметный разговор.
0
0 / 0 / 0
Регистрация: 19.06.2019
Сообщений: 8
20.06.2019, 11:18  [ТС]
вот архив
Вложения
Тип файла: rar Unit221.rar (629 байт, 1 просмотров)
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33411 / 21521 / 8236
Регистрация: 22.10.2011
Сообщений: 36,922
Записей в блоге: 12
20.06.2019, 12:24
tearonbits, кто же один метод внутри другого определяет? Вот так:
Кликните здесь для просмотра всего текста
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
//---------------------------------------------------------------------------
 
#include <vcl.h>
#pragma hdrstop
 
#include "Unit221.h"
#include <memory>
 
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------
 
void __fastcall TForm1::FormCreate(TObject *Sender)
{
   std::auto_ptr<TStringList> L (new TStringList);
   L->LoadFromFile("C:\\TMP\\111.txt");
   Memo1->Lines->Assign(L.get());
   L->CommaText = StringReplace(L->Text, "\r\n", " ", TReplaceFlags() << rfReplaceAll);
   L->Sort();
   Memo2->Clear();
   std::auto_ptr<TStringList> tmp (new TStringList);
   for(int i = 0; i < L->Count; i++)
     {
       int k = tmp->IndexOf(L->Strings[i]);
       if(k == -1) tmp->AddObject(L->Strings[i], (TObject*)1);
       else tmp->Objects[k] = (TObject*)(((int)tmp->Objects[k] + 1));
     }
   for(int i = 0; i < tmp->Count; i++)
     Memo2->Lines->Add(String().sprintf("%s - %d", tmp->Strings[i], (int)tmp->Objects[i]));
}
//---------------------------------------------------------------------------
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.06.2019, 12:24
Помогаю со студенческими работами здесь

Распечатать эту же последовательность слов, удалив из нее повторные вхождения слов
Проверка кода. Распечатать эту же последовательность слов, но удалив из нее повторные вхождения слов; program fefefgdg; var...

Вывести заданную последовательность слов, удалив из неё повторные вхождения слов
Дана последовательность, содержащая от 1 до 30 слов, в каждом из которых от 1 до 5 строчных латинских букв; между соседними...

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

Выведите последовательность слов, удалив из нее повторные вхождения слов
Пусть дана последовательность, содержащая от 1 до 30 слов, в каждом из которых от 1 до 5 строчных латинских букв; между соседними словами...

Напечатать последовательность слов, не удалив из нее повторные вхождения слов
дана последовательность содержащая от 1 до 30 слов, в каждом из которых от 1 до 5 прорисных латинских букв, между соседними словами -...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru