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

Работа с файлами.Требуется корекктировка - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Проверка симметричности булевых функций http://www.cyberforum.ru/cpp-beginners/thread419438.html
Задача:Проверка симметричности Булевых функции, подкиньте идею мне этого хватит, заранее спасибо)
C++ Ввести строку символов, которая есть фрагментом программы и записать в файл Искал по форуму - не нашел. Задача: Ввести строку символов, которая есть фрагментом программы, написанной на языке С++ и записать все это в файл. Подсчитать, сколько раз среди символов появляются "(" и ")". Сохранить результат в файл. zabadzzzz, Правила2.3. Создавайте темы с осмысленными и понятными названиями - это серьезно повышает шансы, что на ваш вопрос ответят.Изначальное название... http://www.cyberforum.ru/cpp-beginners/thread419428.html
C++ 1е-005 -> 0.00001
Здравствуйте. Как в выводе дробного числа заменить "1е-005" на "0.00001", скажем? Спасибо.
C++ заполнить секторы матрицы, которые лежат влево и вправо от главной и побочной диагоналей
помогите, пожалуйста, написать программу на С или С++ Нужно заполнить секторы матрицы, которые лежат влево и вправо от главной и побочной диагоналей, ЛП, от левого верхнего угла вниз - вправо. Остаток матрицы заполнить нулями.
C++ Подсчитать, сколько элементов встречаются в массиве более одного раза. http://www.cyberforum.ru/cpp-beginners/thread419415.html
Помогите пожалуйста кто может. Очень прошу. :cry: Сдать в четверг нужно... Подсчитать, сколько элементов встречаются в данном массиве более одного раза. К задаче у меня получилось что-то такое: #include "stdafx.h" #include <conio.h> #include <clocale> #include <malloc.h>
C++ Разработать алгоритм определяющий взаимное расположение двух прямых в пространстве Разработать алгоритм определяющий взаимное расположение двух прямых в пространстве. прямые задать с помощью структур. результат вывести на экран. помогите пожалуйста задать прямые с помощью структур прямые задаются точкой и направляющим вектором. дальше как делать знаю подробнее

Показать сообщение отдельно
DatIK
2 / 2 / 0
Регистрация: 19.11.2011
Сообщений: 128
28.12.2011, 01:58     Работа с файлами.Требуется корекктировка
Код работает находит самое длинное слово , его длину , но не корректно вычисляет кол-во заданных слов входящих в текст
Пожалуйста решите проблему


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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#define _CRT_SECURE_NO_DEPRECATE
 
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <locale.h>
 
 
int main()
{
    setlocale(LC_ALL, "Russian");      
    char s[255];
    char str[255];
    int count = 0;
    
    //Открытие файла
    FILE *F;
    if((F=fopen("F.txt", "rt")) == NULL)
        {
            printf("Не могу открыть F.txt на чтение.\n");
            getch();
            return -1;
        }
    
    FILE *G;
    G = fopen( "G.txt", "wt+" );
    if((G = fopen( "G.txt", "wt+" )) == NULL)
        {
            printf("Не могу открыть G.txt на запись.\n");
            getch();
            return -2;
        }
    
    char simvol;
    for(int i=0; (simvol=getc(F))!=EOF; i++)
    s[i]=simvol;
    fclose(F);
    printf("Исходный текст:\n%s\n", s);
 
 
    //Поиск слов с максимальной длиной символов
    int maxStart , maxLen=0, len=0;
    for(int i=0; i<strlen(s); i++)
    // i номер позиции в строке
    // maxLen длина самого длинного слова
    // maxStart номер позиции с которой начинается самое длинное слово
    {
       if(s[i]!=' ' && s[i]!='.' && s[i]!='\n' && i<strlen(s)-1)
        {
            len++;
        }
       else
        {
            if(i==strlen(s)-1){len++;i++;}
            if(len>maxLen){maxLen=len; maxStart = i-maxLen;}
            len=0;
        }
    }
    for(int i = maxStart; i < maxLen; i++)
    str[i - maxStart] = s[i - maxStart];
    
    {
        bool switcher;
        for(int i = 0; i < strlen(s); i++)
        {
            if(s[i] == str[0])
            {
                for(int j = 0; j < strlen(str); j++)
                {
                    if(s[j] != str[j])
                    {
                        switcher = true;
                        break;
                    }
                    else
                    {
                        switcher = false;
                    }
                }
                if(!switcher)
                {
                    count++;
                }
            }
        }
    }
    //зная длину самого длинного слова, заного читаем текст для нахожления слов с максимальной длиной
    for(int i=0; i<strlen(s); i++)
    {
        if(s[i]!=' ' && s[i]!='.' && s[i]!='\n' && i<strlen(s)-1)
         {
            len++;
         }
        else
         {
            if(i==strlen(s)-1){len++;i++;}
            if(len==maxLen)
             {
                for(int j=i; j<=maxLen; j++)
                 {
                    s[i] = fgetc(F);  // считываем символ
                    fputc( s[i], G ); // записываем символ
                 }
                    _fcloseall();
             }
                
            len=0;
         }
    }
 
 
 
 
    printf("\nСлово(а) максимальной длины в файле F.txt:\n");
    for(int i=maxStart; i<maxStart+maxLen; i++)
        {
            printf("%c", s[i]);
        }
    printf("\nДлина самого длинного слова равна %d символов.\n", maxLen);
    printf("\n Количество равно %d .\n", count);
 
    
    _getch();
    
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 11:13. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru