Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Lostmen
0 / 0 / 0
Регистрация: 15.03.2011
Сообщений: 13
#1

Определение самого часто встречающегося латинского символа в тексте - C++

15.03.2011, 12:04. Просмотров 555. Ответов 4
Метки нет (Все метки)

Помогите пожалуйста срочно!
Дан произвольный текст количество строк в котором не более 10 а количество символов в каждой строке не более 80 определить какая латинская буква чаще всего встречается в тексте.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.03.2011, 12:04     Определение самого часто встречающегося латинского символа в тексте
Посмотрите здесь:

Нахождение самого часто повторяющегося значения - C++
На вход программе подаются сведения о номерах школ учащихся, участвовавших в олимпиаде. В первой строке сообщается количество учащихся N,...

Найти самый часто встречающийся символ в тексте - C++
я "сделал" программу шифратор и дешифратор текста по методу цезаря, но теперь мне надо сделать так чтобы программа показывала самый...

Поиск самого короткого слова в тексте - C++
Здравствуйте,у меня проблема с функцией поиска самого короткого слова в тексте,писал я ее где-то месяц назад для поиска самого короткого...

Определение самого длинного симметричного слова в строке - C++
Осталось выбрать самое длинное слово..но как? #include <iostream.h> #include <conio.h> #include <stdio.h> #include <string.h> ...

Файловый ввод и поиск самого длинного слова в тексте - C++
Здравствуйте. Нужно написать программу, которая вводит текст, состоящий из нескольких предложений, находит самое длинное слово и...

Определение самого короткого слова в строке: ошибки компиляции - C++
Собс-но ловлю кучу ошибок компиляции,а как их исправить,понятия не имею...Кому не трудно,помогите пожалуйста исправить #include...

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
igorrr37
1644 / 1272 / 133
Регистрация: 21.12.2010
Сообщений: 1,932
Записей в блоге: 7
15.03.2011, 16:20     Определение самого часто встречающегося латинского символа в тексте #2
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
#include<iostream>
#include<fstream>
#include<windows.h>
 
int main() {
    std::fstream fs("1.txt");
    if(!fs){std::cerr<<"Error opening file\n"; return 1;}
    char text[800], *a;
    unsigned char text1[800], *b;
    int chars[256]={0};
    fs.getline(text, sizeof(text), '\0');
    fs.close();
    for(a=text, b=text1; *b=*a; a++, b++);
    for(b=text1; *b; b++){
        ++chars[*b];
    }
    text1[0]='\0';
    for(int i=0; i<256; i++){
        if(chars[i]>chars[text1[0]]) text1[0]=i;
    }
    text[0]=text1[0];
    CharToOem(text, text);
    std::cout<<text[0]<<" "<<chars[text1[0]]<<"\n";
}
IrineK
Заблокирован
15.03.2011, 16:33     Определение самого часто встречающегося латинского символа в тексте #3
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
//Определение самого часто встречающегося латинского символа в тексте///////////////////////////
#include <iostream>
#include <fstream>
#include <string>
#define LEN 80
#define LET 26
using namespace std;
 
char latLetter[LET];
 
//подсчет для каждой из букв по одной строке////////////////////////////////////////////////////
void countLetters(char* buf, int* count)
{   int i,j, len;
    len = strlen(buf);
    for(j=0;j<len;j++)
        for(i=0;i<LET;i++) 
            if(buf[j]==latLetter[i]) count[i]++;
}
 
//чтение и обработка строки из файла////////////////////////////////////////////////////////////
void lineLetters(char* path, int* res)
{   int cur[LET], i;
    ifstream iFSTR;
    iFSTR.open(path);
    char buffer[LEN];
    if(iFSTR.is_open())
    {   while (iFSTR.good())
        {   iFSTR.getline(buffer,LEN,'\n');
                cout<<buffer<<"\n";
                for(i=0;i<LET;i++) cur[i]=0;
                countLetters(buffer,cur);
                for(i=0;i<LET;i++) res[i]+=cur[i]; 
        }
    iFSTR.close();
    }
    else 
    {   cout<<"Error opening file\n";
        cin.get();
        exit(1);
    }
}
 
/////////////////////////////////////////////////////////////////////////////////////////////////
int main()
{
char c, c_max;
int i, max=0;
//создание массива из прописных латинских букв
for(c='a',i=0; c<='z';c++,i++) latLetter[i]=c;
 
//кво повторений для каждой буквы для всех строк
int total[LET];
for(i=0;i<LET;i++) total[i]=0;
lineLetters("test.txt",total);
 
cout<<"File processed. Press ENTER to proceed\n";
cin.get();
 
//вывод результатов, поиск максимума
system("cls");
cout<<"Usage of each letter (times):\n";
for(c='a',i=0; c<='z';c++,i++)
{   cout<<c<<":\t"<<total[i]<<"\n";
    if(total[i]>max) {max = total[i]; c_max=c;}
}
cout<<"\n\nMaximum usage:\t"<<c_max<<":\t"<<max<<"\n";
 
cin.get();
return 0;
}
Lostmen
0 / 0 / 0
Регистрация: 15.03.2011
Сообщений: 13
15.03.2011, 17:14  [ТС]     Определение самого часто встречающегося латинского символа в тексте #4
Спасибо большое!!!
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.03.2011, 19:21     Определение самого часто встречающегося латинского символа в тексте
Еще ссылки по теме:

Функция, определяющая позицию самого первого вхождения заданного символа в исходную строку - C++
Прошу помочь решить задачки!:(очень нужно (Билет №25) Составить функцию, позволяющую определить позицию самого первого вхождения...

Функция, возвращающая номер самого правого вхождения заданного символа во введенную строку - C++
Нужна помощь в составлении программы: возвращающую номер самого правого вхождения заданного символа во введенную строку. Если символ не...

подсчитать, как часто (в %) встречаются в тексте различные символы (всего 256, текст прочитать из файла) - C++
сабж.. может вы скажите, что это пустяк, но мне это трудновато сделать... кто может, помогите пожалуйста :sorry: написана программа...

Подсчёт символа в тексте - C++
Помогите пожалуйста решить такое задание: входной файл содержит некоторый текст(только цифры). для каждой цифры требуется посчитать,...


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

Или воспользуйтесь поиском по форуму:
asics
Freelance
Эксперт С++
2846 / 1783 / 144
Регистрация: 09.09.2010
Сообщений: 3,841
15.03.2011, 19:21     Определение самого часто встречающегося латинского символа в тексте #5
Еще вариант
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
#include <iostream>
#include <set>
#include <algorithm>
#include <iterator>
#include <fstream>
#include <cctype>
 
int main(){
  std::ifstream f_in("INPUT.TXT");
  static std::multiset<char> a;
  while(!f_in.eof()){
    char ch = f_in.get();
    if( isalpha(ch) )
      a.insert(ch);
  }
  struct func_for_set{
    bool operator() (const char& a_, const char& b_) const{
      return a.count(a_) > a.count(b_);
    }
  };
  std::set<char, func_for_set> b;
  for(std::multiset<char>::iterator it = a.begin(); it != a.end(); ++it)
    b.insert(*it);
  std::cout << "\n\nResult -> " << *b.begin() << std::endl;
  return 0;
}
Yandex
Объявления
15.03.2011, 19:21     Определение самого часто встречающегося латинского символа в тексте
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru