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

Поиск самого короткого слова в тексте - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Матрица http://www.cyberforum.ru/cpp-beginners/thread265535.html
Помогите пожалуйста с программой, даже не знаю как это сделать ((( Программу нужно написать на С с использованием функций. Задание: Сформировать матрицу M на N. Задать прямоугольник, который будит...
C++ функция strtok расскажите алгоритм char str ="- This, a sample string."; char * pch; printf ("Splitting string \"%s\" into tokens:\n",str); pch = strtok (str," ,.-"); while (pch != NULL) { ... http://www.cyberforum.ru/cpp-beginners/thread265512.html
C++ Графы
Имеется сеть автомобильных дорог. Известны расстояния всех участков дорог. Некоторые участки аварийноопасны. Требуется найти путь из пункта А в пункт В, имеющий наименьшую суммарную протяженность...
Организовать два индексных файла для быстрого поиска информации C++
В файле записаны фамилии студентов и их анкетные данные, включающие номера паспорта и зачетной книжки. Организовать два индексных файла для быстрого поиска информации по любому из этих номеров....
C++ Как сделать обработчик для меню? http://www.cyberforum.ru/cpp-beginners/thread265499.html
Я для для программы на c++ сделал меню, подскажите как сделать обработчик и куда этот код потом вставлять???
C++ Матрицы(max and min) Переставить местами строки содержащие первый максимальный элемент и последний минимальный Элемент в Матрице подробнее

Показать сообщение отдельно
ZevS13
2 / 2 / 0
Регистрация: 05.12.2010
Сообщений: 15

Поиск самого короткого слова в тексте - C++

28.03.2011, 14:57. Просмотров 991. Ответов 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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#include <iostream>
#include <fstream>
#include <string>
using namespace std;
int ProvRazm();
int Vivodnaekran();
int SamKorotkSlov();
 
 int main()
 {
    
     setlocale(0,"rus");
     string buf;
     ifstream file("text.DAT"); /*Открываем файл*/
     if(!file.is_open())            /*Проверяем файл*/
     {
         cerr<<"Файла нету!!проверь имя файла!или его наличие!"<<endl;
         getchar();
         return 1;
     }
    ProvRazm();
    Vivodnaekran();
    SamKorotkSlov();
    system("pause");
    return 0;
 
     
 }
 int ProvRazm()
{
    
    FILE *in=fopen("text.dat","r");//открытие потока
                    //с параметром "только для чтения"
    int sum=0;
    char buf[72];
    while(!feof(in))//проверка размеров текста
    {
        fgets(buf,72,in);//ф-ция коп. одной строки из файла
        if(strlen(buf)>70)//проверка длины строки
        {
            cout<<"Размер строк слишком велик(не больше 70).\n";
            
        }
        sum+=strlen(buf);//ф-ция подсчета кол-ва символов в строке
    }
    if(sum>1000)
    {
        cout<<"Большое колличество символов(не больше 1000).\n";
        
    }
    fclose(in);//закрытие потока
    getchar();
    return sum;//возвращение кол-ва символов в файле
}
 
 
 int Vivodnaekran()
 {
     string buf;
     ifstream file("text.DAT");
     cout<<"Содержимое файла:"<<endl;
     while ( getline(file, buf) )
    {
                cout << buf << endl;
    }
     return 1;
 }
 
 int SamKorotkSlov()
 {  
char str[1000];
   //curlen - текущая длина слова
   //maxlen - максимальная длина слова
   //index - индекс, соответствующий позиции
   //конца самого длинного слова +1
int curlen = 0, maxlen = 0, index = 0, i;
  ifstream file("text.DAT");
 for(i=0;;i++)
   {
     if(str[i]==' '|| str[i]=='\0'){
         if(curlen>maxlen){
           maxlen = curlen;
             index = i;
         }
         //если конец строки -> выйти из цикла
         if(str[i]=='\0')break;
         curlen = 0;
      }
      else curlen++;
   }
 cout << "" <<maxlen<<endl;
   getchar ();
   return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.