С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
5oundtech
0 / 0 / 0
Регистрация: 11.11.2013
Сообщений: 42
#1

Поиск самого длинного слова в файле - C++

28.11.2013, 23:18. Просмотров 1013. Ответов 4
Метки нет (Все метки)

Создать файл file.txt с помощью текстового редактора, длина которого не превышает 70 символов. Написать программу, которая:
1) выводит текст на экран дисплея
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
#include "stdafx.h"
#include <iostream>
#include "stdio.h"
#include <ctype.h>
#include <conio.h>
#include <string.h>
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    const int n = 70;
    char *s1,a[n];
    int curlen=0,maxlen=0,index=0, j;
    s1="D:\\dota2launchopt.txt";
        FILE *f1;
    if((f1=fopen(s1,"r"))==0)
    {
        cout<<"\nError\n";
return 1;
    }
    int i=0;
    while (!feof(f1))
        fread(&a[i++],sizeof(char),1,f1);
    a[i-1]=0;
    cout<<a<<endl;
for(j=0;;j++)
{
    if(a[j]==' '|| a[j]=='\0')
    {
        if(curlen>maxlen){
            maxlen=curlen;
            index = j;
        }
        if(a[j]=='\0')break;
        curlen = 0;
    }
    else curlen++;
}
    cout<< ""<<maxlen<<endl;
 
    system("pause");
    return 0;
}
1ая часть задания готова полностью.
Собственно у меня выводит число, а как сделать так что бы выводило само слово?

Добавлено через 54 минуты
Я долго ломал голову,но так и не нашел решение.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.11.2013, 23:18
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Поиск самого длинного слова в файле (C++):

Поиск самого длинного слова в файле - C++
Дан символьный файл f. Найти самое длинное слово среди слов, вторая буква которых есть е; если слов с наибольшей длинной несколько, то...

Поиск самого длинного слова в файле - C++
вот задание Задание к лабораторной работе № 7. Ввод данных осуществляется из файла с pасшиpением .DAT. Использовать ТОЛЬКО...

Разработать программу, осуществляющую поиск самого короткого и самого длинного слова во вводимом тексте - C++
Разработать программу, осуществляющую поиск самого короткого и самого длинного слова во вводимом тексте. С комментами)

Поиск самого короткого и самого длинного слова массива - C++
Возникла проблема, программа наименьшим считает всегда первое слово #include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;locale&gt; ...

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

Строки (Найти длину самого короткого и самого длинного слова, а также сами эти слова) - C++
Люди, подскажите, плиз, как написать програмку в с++ за условием, что дана строка, состоящая из слов, разделенных пробелами (одним или...

4
genaryok
22 / 22 / 4
Регистрация: 18.10.2013
Сообщений: 62
29.11.2013, 00:22 #2
Ну, в принципе, если есть длина максимального слова, то можно еще раз пройтись по тексту и вывести те слова, длина которых=4
0
zhenek_1980
0 / 0 / 0
Регистрация: 24.11.2013
Сообщений: 4
29.11.2013, 06:57 #3
можно завести структуру в которой будет лежать слово и которая возвращает длину его, потом создать список с этой структурой и отсортировать его а также отпарсить текст

Добавлено через 37 минут
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
class cword
{
    private :
        std::string s ;
 
    public :
        void set_word(std::string _s) { s = _s ; }
        int get_count_letters() { return s.length() ; }
        std::string get_word() { return s ; }
};
 
class sort_cwords
{
public :
    bool operator() (cword &obj1, cword &obj2)
    {
        return obj1.get_count_letters() > obj2.get_count_letters() ;
    }
};
 
int _tmain(int argc, _TCHAR* argv[])
{
    //char * a = "111111111111 rggg eger erert ertertert reterrrrrrrrrrrrrr 12 123 1234" ;
    std::string s = a ; // <---------------здесь надо подставить что было принято из файла
    std::list<cword> list_words ;
    
    while(1)
    {
        cword obj ;
 
        int pos = s.find(' ') ;
        if(pos == -1) 
        {
            obj.set_word(s) ;
            list_words.push_back(obj) ;
            break ;
        }
 
        obj.set_word(s.substr(0,pos)) ;
        list_words.push_back(obj) ;
 
        s = s.substr(pos + 1,s.length() - pos) ;
    }
 
    list_words.sort(sort_cwords()) ;
 
    std::list<cword>::iterator i = list_words.begin() ;
    std::cout << i->get_word().c_str() << " big word" << std::endl ;
    int t ; std::cin >> t ;
 
    return 0;
}
Добавлено через 5 часов 50 минут
Можно и без list и класса писать тогда в while надо запоминать слово и сравнивать его с другими, также надо проверить если в предложении нет слов, а то я не проверял
0
5oundtech
0 / 0 / 0
Регистрация: 11.11.2013
Сообщений: 42
29.11.2013, 14:23  [ТС] #4
Спасибо за помощь, но я все же додумался до правильного варианта. Структуры к сожалению еще не прошел.
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 "stdafx.h"
#include <iostream>
#include <stdlib.h>
#include <conio.h>
#include <stdio.h>
#include <string>
 
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale( LC_ALL,"Russian" );
    const char n = 70;
    char *s1,a[n];
    s1="D:\\file.txt";
        FILE *f1;
    if((f1=fopen(s1,"r"))==0)
    {
        cout<<"\nError\n";
return 1;
    }
    int i=0;
    while (!feof(f1))
        fread(&a[i++],sizeof(char),1,f1);
    a[i-1]=0;
    cout<<a<<endl;
 char * pch = strtok (a," "),
         * word = 0; //
 
    int length = strlen(pch);
 
    int maxLen = 0;
 
      while (pch != NULL)
      {
          length = strlen(pch);
 
          if (maxLen < length )
          {
              maxLen = length;
              word = pch;
          }
 
          pch = strtok (NULL, " ");
      }
 
      cout << "Самое длинное слово: " << word
           << " , его длина равна: " << maxLen
           << " символам " << endl;
 
getch();
    system("pause");
    return 0;
}
0
DiffEreD
1431 / 768 / 95
Регистрация: 21.06.2011
Сообщений: 1,740
Записей в блоге: 2
29.11.2013, 16:31 #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 <string>
#include <fstream>
#include <iterator>
#include <algorithm>
 
int main()
{
    std::ifstream ifs("D:/file.txt");
    if (!ifs.is_open())
        return 1;
 
    using input = std::istream_iterator<std::string>;
 
    std::cout << "All worlds:\n\n";
    std::copy(input(ifs), input(), std::ostream_iterator<std::string>(std::cout, " "));
    ifs.clear();
    ifs.seekg(0);
 
    std::cout << "\n\nBiggest word is:  -> " <<
        *std::max_element(input(ifs), input(), [](const std::string& s1, const std::string& s2)
    { return s1.size() < s2.size(); });
    std::cout << std::endl;
 
    return 0;
}
0
29.11.2013, 16:31
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.11.2013, 16:31
Привет! Вот еще темы с ответами:

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

Найти длину самого короткого слова и самого длинного слова в строке - C++
помогите!!! Дана строка, содержащая текст. Найти длину самого короткого слова и самого длинного слова.

Дана строка, содержащая текст. Найти длину самого короткого и самого длинного слова. - C++
1. Дана строка, содержащая текст. Найти длину самого короткого и самого длинного слова. 2. 14.14. Имеется строка, содержащая буквы...

Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова. - C++
помогите написать программу =) очень нужно=) Дана строка содержащая текст. Найти длину самого короткого и самого длинного слова.


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

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

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