С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.92/26: Рейтинг темы: голосов - 26, средняя оценка - 4.92
0 / 0 / 0
Регистрация: 30.05.2010
Сообщений: 10

Определить какое слово в строке встречается чаще всего

01.06.2010, 11:59. Показов 5642. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
ребят,помогите.Для Вас же это как семечки

1. Определить какое слово в строке встречается чаще всего
2. Подсчитать количество букв а в последнем слове.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.06.2010, 11:59
Ответы с готовыми решениями:

Определить, какое слово встречается в строке чаще всего
1. Определить какое слово встречается в строке чаще всего. можно с пояснениями если не сложно

Определить, какое слово встречается в строке чаще всего
Задана строка, которая состоит из символов. Символы сочетают в слова. Слова отделяются одним или несколькими пробелами. В конце текста...

Определить, какое слово в строке встречается чаще всего
Определить какое слово встречается в строке чаще всего.

9
37 / 37 / 2
Регистрация: 13.05.2010
Сообщений: 81
01.06.2010, 13:08
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
#include <iostream>
#include <fstream>
#include <string>
#include <ctype.h>
using namespace std;
 string f(string, int);
 int kolvo=0; int *p=&kolvo;
//void sort(string *p, int);
int main(){
    ifstream in ("111.txt");
    //ofstream out ("222.txt");
    
    string a; 
while (getline (in,a)){
    a+="\n";
    int i=0; while (a[i]) i++;
    cout<<f(a, i)<<endl;
    cout <<kolvo;}
    in.close(); 
    cin.get ();
    return 0;}
string f(string a ,int ii){
    
    bool l=true;
    string temp[40];
    int n1=0, k1=0; // n1 количество слов
    int *n=new int[40]; int *k=new int[40]; //индексы n начала слова, k конца слова
    
    if (a[0]!=' ') {n[0]=0; n1++;} else l=false;
    int i=0;
    for ( i=0; i<=ii;i++)
    {   if  (l && (a[i]==' ' || ispunct(int(a[i])))) {*(k+k1)=i-1; k1++; l=false;}
        if (a[i+1]=='\n') break;
        if (a[i]==' ' && a[i+1] !=' '&& ispunct(int(a[i+1]))==false) {*(n+n1)=(i+1); n1++; l=true;}
        }
    if (n1>k1) k[n1-1]=i; // записываем последний индекс если его нет
 
    
    int iii,d; // собираем буквы в слово и потом в массив
    for ( d=0; d<n1;d++) { 
        string stemp;
        for (iii=n[d]; iii<=k[d];iii++) stemp+=a[iii];
        
        temp[d]=stemp;}
    int slovo=0, num=0;
    for (iii=0; iii<n1; iii++){i=0; for (d=iii; d<n1; d++) if (temp[d]==temp[iii]) i++;
    if (slovo<i) {num=iii; slovo=i;}}
    for (i=n[n1-1]; i<=k[n1-1]; i++) if (a[i]=='a') *p+=1; 
 
        delete []n; delete []k;
        
        return temp[num];}
оформишь как хочешь спешу
0
Шаровик затейник
 Аватар для Crudelis
696 / 445 / 78
Регистрация: 06.05.2010
Сообщений: 1,109
01.06.2010, 13:13
2.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
using namespace std;
 
void main ()
{
    char str[250];
    int count=0;
    cout<<"Vvedite stroku\n";
    gets(str);
    int l=strlen(str);
    for(int i=l-1;i>0;i--)
    {
        if(str[i]!=' '&&str[i]!='.'&&str[i]!=','&&str[i]!='-'&&str[i]!=':'&&str[i]!=';'&&str[i]!='!'&&str[i]!='?')
            count++;
        else
            break;
    }
    cout<<"V poslednem slove "<<count<<" bukv\n";
    cout<<endl;
}
использовал проверку на все знаки препинания
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
01.06.2010, 14:53
Цитата Сообщение от Crudelis Посмотреть сообщение
использовал проверку на все знаки препинания
C++
1
2
3
4
#include <cctype>
...
                if ( ! ispunct(str[i]) && ! isspace(str[i]) )
...
0
0 / 0 / 0
Регистрация: 30.05.2010
Сообщений: 10
02.06.2010, 17:17  [ТС]
но вторая задача выдаёт 0 букв

Добавлено через 17 часов 2 минуты
ребята,а первая что то отказуется работать
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
02.06.2010, 18:23
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
#include <iostream>
#include <map>
#include <string>
#include <sstream>
#include <algorithm>
#include <functional>
 
class Cmp : public std::binary_function<std::pair<std::string, int>, std::pair<std::string, int>, bool> {
public:
    bool operator () (const std::pair<std::string, int> & a, const std::pair<std::string, int> & b) {
        return a.second < b.second;
    }
};
 
int main(){
    std::string buf, tmp;
 
    std::cout << "String: ";
    std::getline(std::cin, buf);
    if ( buf.empty() )
        return 1;
    std::istringstream ist(buf);
    std::map<std::string, int> words;
    while ( ist >> tmp )
        words[tmp]++;
 
    std::cout << "First most often meeting word is \""
            << (std::max_element(words.begin(), words.end(), Cmp()))->first << "\"" << std::endl;
 
    return 0;
}
Добавлено через 6 минут
2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
#include <string>
#include <sstream>
#include <algorithm>
 
int main(){
    const char TO_FIND = 'a';
    std::string buf, tmp;
    std::cout << "String: ";
    std::getline(std::cin, buf);
    if ( buf.empty() )
        return 1;
    std::istringstream ist(buf);
    while ( ist >> tmp )
        ;
    std::cout << std::count(tmp.begin(), tmp.end(), TO_FIND) << " letters '" << TO_FIND
            <<"' in last word." << std::endl;
 
    return 0;
}
1
37 / 37 / 2
Регистрация: 13.05.2010
Сообщений: 81
02.06.2010, 22:51
Цитата Сообщение от non Посмотреть сообщение
но вторая задача выдаёт 0 букв
Добавлено через 17 часов 2 минуты
ребята,а первая что то отказуется работать
прога абсолютно корректная в соотвествии с поставленной задачей. Выполняет и 1ю и 2ю задачи.
если же строк много нужно дописать endl; после cout <<kolvo; и обнулить значение для новой строки методом трудоёмкой записи типа *p=0 но уже после endl;
1
425 / 229 / 87
Регистрация: 25.03.2009
Сообщений: 744
02.06.2010, 23:46
easybudda, STL в бой?)
1
Шаровик затейник
 Аватар для Crudelis
696 / 445 / 78
Регистрация: 06.05.2010
Сообщений: 1,109
03.06.2010, 00:35
easybudda, мы ещё такого не проходили) данная ф-ция проверяет строку на знаки препинания?
1
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
03.06.2010, 00:39
Цитата Сообщение от Crudelis Посмотреть сообщение
данная ф-ция проверяет строку на знаки препинания?
Шилдт "Полный справочник по С"
#include <ctype.h>
int ispunct(int ch);

Функция ispunct() возвращает ненулевое значение, если аргумент ch является знаком пунктуации. В противном случае возвращается нуль. Под знаками пунктуации подразумеваются все печатаемые символы за исключением пробела, которые не относятся к алфавитно-цифровым.
#include <ctype.h>
int isspace(int ch);

Функция isspace() возвращает ненулевое значение, если аргумент ch является пробельным символом. (К пробельным символам, помимо пробела, относятся символы горизонтальной и вертикальной табуляции, перевода страницы, возврата каретки и новой строки.) В противном случае возвращается нуль.
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.06.2010, 00:39
Помогаю со студенческими работами здесь

Выполнить ввод строки и определить какое слово встречается в строке чаще всего
Задана строка, состоящая из символов. Символы объединяются в слова. Слова друг от друга отделяются одним или несколькими пробелами. В...

Определить, какое слово чаще встречается в строке - первое или последнее (перевести с паскаля на си)
определить, каких слов больше в строке первого или последнего. вывести первое и последнее слова на экран. var ...

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

Определить слово, которое чаще всего встречается в файле
Помогите пожалуйста с задачей. Желательно простое решение в потоках. Строки текстового файла input. txt состоят из слов, разделенных...

Определить какая цифра в строке встречается чаще всего
Почему эта программа не работает ?Что нужно исправить ,как должен выглядеть исправленный вариант :? Заранее спасибо :3 Написать...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru