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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 4.85
non
0 / 0 / 0
Регистрация: 30.05.2010
Сообщений: 10
#1

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

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

ребят,помогите.Для Вас же это как семечки

1. Определить какое слово в строке встречается чаще всего
2. Подсчитать количество букв а в последнем слове.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.06.2010, 11:59
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Определить какое слово в строке встречается чаще всего (C++):

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

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

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

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

Определить какой знак препинания(-,.:) встречается в строке чаще всего - C++
Как решать, нашел на символы, но не на знаки препинания. Помогите плиз. #include <iostream> #include <string> using namespace std;...

Массивы строк. Какой символ встречается в этой строке чаще всего? - C++
напишите программу которая принимает с клавы строку и определяет какой символ встречается в этой строке чаще всего. Если таких символов...

9
edd
36 / 36 / 0
Регистрация: 13.05.2010
Сообщений: 81
01.06.2010, 13:08 #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
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
Шаровик затейник
674 / 416 / 13
Регистрация: 06.05.2010
Сообщений: 1,109
01.06.2010, 13:13 #3
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
easybudda
Модератор
Эксперт CЭксперт С++
9683 / 5633 / 956
Регистрация: 25.07.2009
Сообщений: 10,813
01.06.2010, 14:53 #4
Цитата Сообщение от Crudelis Посмотреть сообщение
использовал проверку на все знаки препинания
C++
1
2
3
4
#include <cctype>
...
                if ( ! ispunct(str[i]) && ! isspace(str[i]) )
...
0
non
0 / 0 / 0
Регистрация: 30.05.2010
Сообщений: 10
02.06.2010, 17:17  [ТС] #5
но вторая задача выдаёт 0 букв

Добавлено через 17 часов 2 минуты
ребята,а первая что то отказуется работать
0
easybudda
Модератор
Эксперт CЭксперт С++
9683 / 5633 / 956
Регистрация: 25.07.2009
Сообщений: 10,813
02.06.2010, 18:23 #6
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
edd
36 / 36 / 0
Регистрация: 13.05.2010
Сообщений: 81
02.06.2010, 22:51 #7
Цитата Сообщение от non Посмотреть сообщение
но вторая задача выдаёт 0 букв
Добавлено через 17 часов 2 минуты
ребята,а первая что то отказуется работать
прога абсолютно корректная в соотвествии с поставленной задачей. Выполняет и 1ю и 2ю задачи.
если же строк много нужно дописать endl; после cout <<kolvo; и обнулить значение для новой строки методом трудоёмкой записи типа *p=0 но уже после endl;
1
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
02.06.2010, 23:46 #8
easybudda, STL в бой?)
1
Crudelis
Шаровик затейник
674 / 416 / 13
Регистрация: 06.05.2010
Сообщений: 1,109
03.06.2010, 00:35 #9
easybudda, мы ещё такого не проходили) данная ф-ция проверяет строку на знаки препинания?
1
easybudda
Модератор
Эксперт CЭксперт С++
9683 / 5633 / 956
Регистрация: 25.07.2009
Сообщений: 10,813
03.06.2010, 00:39 #10
Цитата Сообщение от Crudelis Посмотреть сообщение
данная ф-ция проверяет строку на знаки препинания?
Шилдт "Полный справочник по С"
#include <ctype.h>
int ispunct(int ch);

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

Функция isspace() возвращает ненулевое значение, если аргумент ch является пробельным символом. (К пробельным символам, помимо пробела, относятся символы горизонтальной и вертикальной табуляции, перевода страницы, возврата каретки и новой строки.) В противном случае возвращается нуль.
2
03.06.2010, 00:39
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.06.2010, 00:39
Привет! Вот еще темы с ответами:

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

Определить какая согласная чаще всего встречается - C++
введено предложение произвольной длины, определить, какая согласная чаще всего встречается в нем

Определить какое из чисел встречается в массиве чаще - C++
Помогите написать код. Проверить есть ли в массиве А числа В и С и определить, какое из чисел встречается в массиве чаще

Определить какая буква чаще всего встречается в текстовом файле - C++
Определить какая буква чаще всего встречается в текстовом файле


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

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

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