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

Коментарии к программе

03.07.2012, 00:49. Показов 703. Ответов 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
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
#include "stdio.h"
#include "iostream"
#include "string.h"
#include "windows.h"
 using namespace std;
 
char *ltrim(char *S)//удаляет пробелы из начала строки
{
    int i,l=strlen(S);//возврат длины строки
    
    for (i=0;i<l;i++) 
    
    {
        if(*S !=' ')break;
        S++;
    }
 
    return S;
}
 
int main(int argc, char* argv[])
{
    FILE *Inp;
 
    int i,j,k,pi,pj;
    char Finp[100];//объявляются массивы
    char Buf[500];//объявляются массивы
    char Phrases [500][500];//объявляются массивы
    char c;
    char *Stro;//создается указатель
    // Для вывода русских букв
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    // Чистим хранилище
    for (i=0; i < 500; i++)
        for (j=0; j < 500; j++) Phrases[i][j]=0;
    // Запрос имени файла
    cout<<"inpFile Name: ";
    cin>>Finp;
    // Открываем файл
    Inp=fopen(Finp,"r");
    if (Inp == NULL)
    {
        cout<<"Error by open!"<<endl;
        return -1;
    }
    // Главный цикл обработки
    pi=0;//изначально pi массива Phrases =0
    pj=0;//изначально pj массива Phrases =0
    while (1)
    {
        // Чистка буфера
        for (i=0; i < 500; i++) Buf[i]=0;
        // Читаем очередную строку
        if (fgets(Buf,500,Inp) == NULL)
        {
            k=0;
            break;//досрочный выход из цыкла
        }
        // Обработка
        for (i=0; i < 500; i++)
        {
            c=Buf[i];  // очередной символ
            if (c == 0) break;  // конец строки
            if ((c != 13) && (c != 10)) // переводы строки 
            {
                   Phrases [pi][pj++]=c;    // кладем правильный символ на место
 
                if ((c == '.') || (c == '!') || (c == '?'))  // конец фразы
               {
                    pi++;  // переход на новую строку массива Phrases
                    pj=0;
               }
 
            }
        }
 
    }
 
    // Закрываем файл
 
    fclose(Inp);
 
    // Печатаем фразы с однобуквенным первым словом
 
    for (i=0; i < pi; i++)
    {
        Stro=ltrim(Phrases [i]);
        if (Stro[1] == ' ') cout << Stro << endl;
    }
 
    // А теперь выводится все остальные
 
    for (i=0; i < pi; i++)
    {
        Stro=ltrim(Phrases [i]);
        if (Stro[1] != ' ') cout << Stro << endl;
    }
 system("PAUSE") ;
    return 0;
 
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.07.2012, 00:49
Ответы с готовыми решениями:

Коментарии к программе
Все доброго времени суток.Можете объяснить что выполняет функция в программ?))) Буду благодарен за помощь))) #include...

Коментарии к программе
Всем привет,можете объяснить часть программы?))) Я понимаю, что в этой части программы(вторая функция) происходит поиск элементов между...

Нужно написать коментарии к программе
Нужно написать коментарии к программе. #include &lt;iostream&gt; using namespace std; void main(){ const int size = 5; int...

5
 Аватар для zvoronz
273 / 241 / 56
Регистрация: 29.05.2012
Сообщений: 889
03.07.2012, 01:00
А тех комментов что есть мало что ли?
Вам что то конкретно не понятно в программе?
0
0 / 0 / 0
Регистрация: 25.12.2011
Сообщений: 13
03.07.2012, 01:12  [ТС]
ну где происходит поиск однобуквенных слов и ща я проставлю вопросы где мне нужны коменты
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
#include "stdio.h"
#include "iostream"
#include "string.h"
#include "windows.h"
 using namespace std;
 
char *ltrim(char *S)//удаляет пробелы из начала строки
{
    int i,l=strlen(S);//возврат длины строки
    
    for (i=0;i<l;i++) //?
    
    {
        if(*S !=' ')break;
        S++;
    }
 
    return S;
}
 
int main(int argc, char* argv[])
{
    FILE *Inp;
 
    int i,j,k,pi,pj;
    char Finp[100];//объявляются массивы
    char Buf[500];//объявляются массивы
    char Phrases [500][500];//объявляются массивы
    char c;
    char *Stro;//создается указатель
    // Для вывода русских букв
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    // Чистим хранилище
    for (i=0; i < 500; i++)//?
        for (j=0; j < 500; j++) Phrases[i][j]=0;//?
    // Запрос имени файла
    cout<<"inpFile Name: ";
    cin>>Finp;
    // Открываем файл
    Inp=fopen(Finp,"r");
    if (Inp == NULL)
    {
        cout<<"Error by open!"<<endl;
        return -1;
    }
    // Главный цикл обработки
    pi=0;//изначально pi массива Phrases =0
    pj=0;//изначально pj массива Phrases =0
    while (1)
    {
        // Чистка буфера
        for (i=0; i < 500; i++) Buf[i]=0;
 
        // Читаем очередную строку
        if (fgets(Buf,500,Inp) == NULL)
        {
            k=0;
            break;//досрочный выход из цыкла
        }
        // Обработка
        for (i=0; i < 500; i++)
        {
            c=Buf[i];  // очередной символ
            if (c == 0) break;  // конец строки (подробнее)
            if ((c != 13) && (c != 10)) // перевод строки(подробнее) 
            {
                   Phrases [pi][pj++]=c;    // кладем правильный символ на место (подробнее)
 
                if ((c == '.') || (c == '!') || (c == '?'))  // конец фразы
               {
                    pi++;  // переход на новую строку массива Phrases
                    pj=0;
               }
 
            }
        }
 
    }
 
    // Закрываем файл
 
    fclose(Inp);
 
    // Печатаем фразы с однобуквенным первым словом
 
    for (i=0; i < pi; i++)//?
    {
        Stro=ltrim(Phrases [i]);
        if (Stro[1] == ' ') cout << Stro << endl;//?
    }
 
    // А теперь выводится все остальные
 
    for (i=0; i < pi; i++)
    {
        Stro=ltrim(Phrases [i]);
        if (Stro[1] != ' ') cout << Stro << endl;
    }
 system("PAUSE") ;
    return 0;
 
}
0
0 / 0 / 0
Регистрация: 25.12.2011
Сообщений: 13
03.07.2012, 01:32  [ТС]
Последняя прога к которой мне нужны комментарии.
я часть подписал,где стоят вопросительные знаки не знаю))
просьба пояснить мне, что в этих строчках происходит.

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
#include <iostream>
#include <conio.h>
#include <stdlib.h>
using namespace std;
 
struct traine
{
    //структура
    unsigned long time;            //время отправления в секундах
    unsigned short number;        //номер поезда
    char *station;                //имя станции
    traine *left,*right;
};      
traine* add(traine *beg, unsigned short number, unsigned long time, char station[50])    //функция добавления элемента 
{
    if (!beg) //если не равно 0
    {                        
        traine *temp=new traine;//? 
        temp->number=number;//? 
        temp->time=time;
        temp->station = new char[50];
        temp->station=station;
        temp->left=0;//? 
        temp->right=0;//? 
        return temp;
    }               
    else if ((number)>(beg->number)) //? 
    {    //бОльшие номера идут в правое поддерево
        beg->right=add(beg->right,number, time, station);
        return beg;
    }
    else 
    {        //меньшие номера идут в левое поддерево
        beg->left=add(beg->left,number, time, station);
        return beg;
    }
}
void show_all(traine *temp)//? 
}
часть проги.
0
 Аватар для zvoronz
273 / 241 / 56
Регистрация: 29.05.2012
Сообщений: 889
03.07.2012, 01:43
Помог чем смог
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
#include <iostream>
#include <conio.h>
#include <stdlib.h>
using namespace std;
 
struct traine
{
    //структура
    unsigned long time;            //время отправления в секундах
    unsigned short number;        //номер поезда
    char *station;                //имя станции
    traine *left,*right;
};      
 
traine* add(traine *beg, unsigned short number, unsigned long time, char station[50])    //функция добавления элемента 
{
    if (!beg) //если не равно 0(тоесть в дереве ещё нет элементов(поездов))
    {                        
        traine *temp=new traine;//выделяем в куче память под новый элемент
        temp->number=number;//устанавливаем ему номер переданный в параметрах(думаю это номер поезда)
        temp->time=time;//устанавливаем время для данного поезда(что за время не понятно, то ли отправления то ли прибытия)
        temp->station = new char[50]; //выдиляем в куче память для хранения названия станции(тоже не понятно, ну и в общем мне это не важно)
        temp->station=station;
        temp->left=0;//обнуляем указатель на левый элемен
        temp->right=0;//обнуляем указатель на правый элемен
        return temp;// возвращаем указатель созданный элемент дерева
    }               
    else if ((number)>(beg->number)) //сравниваем номер добавляемого и корневого поезда
    {    //бОльшие номера идут в правое поддерево
        beg->right=add(beg->right,number, time, station);
        return beg;
    }
    else 
    {        //меньшие номера идут в левое поддерево
        beg->left=add(beg->left,number, time, station);
        return beg;
    }
}
void show_all(traine *temp)/. а тут не хватает кода но по названию понятно что процедура выводит дерево наверное на консоль :)
}
2
 Аватар для zvoronz
273 / 241 / 56
Регистрация: 29.05.2012
Сообщений: 889
03.07.2012, 01:51
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
#include "stdio.h"
#include "iostream"
#include "string.h"
#include "windows.h"
 using namespace std;
 
char *ltrim(char *S)//удаляет пробелы из начала строки
{
    int i,l=strlen(S);//возврат длины строки
    
    for (i=0;i<l;i++) //цикл который переберает все символы строки 
    
    {
        if(*S !=' ')break;
        S++;
    }
 
    return S;
}
 
int main(int argc, char* argv[])
{
    FILE *Inp;
 
    int i,j,k,pi,pj;
    char Finp[100];//объявляются массивы
    char Buf[500];//объявляются массивы
    char Phrases [500][500];//объявляются массивы
    char c;
    char *Stro;//создается указатель
    // Для вывода русских букв
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    // Чистим хранилище
    for (i=0; i < 500; i++)//тут объявлено два вложенных цикла для перебора всех элементов матрицы размером 500х500
        for (j=0; j < 500; j++) Phrases[i][j]=0;//обнуляем все элементы массива(
    // Запрос имени файла
    cout<<"inpFile Name: ";
    cin>>Finp;
    // Открываем файл
    Inp=fopen(Finp,"r");
    if (Inp == NULL)
    {
        cout<<"Error by open!"<<endl;
        return -1;
    }
    // Главный цикл обработки
    pi=0;//изначально pi массива Phrases =0
    pj=0;//изначально pj массива Phrases =0
    while (1)
    {
        // Чистка буфера
        for (i=0; i < 500; i++) Buf[i]=0;
 
        // Читаем очередную строку
        if (fgets(Buf,500,Inp) == NULL)
        {
            k=0;
            break;//досрочный выход из цыкла
        }
        // Обработка
        for (i=0; i < 500; i++)
        {
            c=Buf[i];  // очередной символ
            if (c == 0) break;  // конец строки (подробнее)
            if ((c != 13) && (c != 10)) // перевод строки(подробнее) 
            {
                   Phrases [pi][pj++]=c;    // кладем правильный символ на место (подробнее)
 
                if ((c == '.') || (c == '!') || (c == '?'))  // конец фразы
               {
                    pi++;  // переход на новую строку массива Phrases
                    pj=0;
               }
 
            }
        }
 
    }
 
    // Закрываем файл
 
    fclose(Inp);
 
    // Печатаем фразы с однобуквенным первым словом
 
    for (i=0; i < pi; i++)//ну это просто цикл который выведет все однобуквенные фразы подсчитанные рание на консоль
    {
        Stro=ltrim(Phrases [i]);
        if (Stro[1] == ' ') cout << Stro << endl;//если первый элемент строки не пробел то выводим эту строку на консоль
    }
 
    // А теперь выводится все остальные
 
    for (i=0; i < pi; i++)
    {
        Stro=ltrim(Phrases [i]);
        if (Stro[1] != ' ') cout << Stro << endl;
    }
 system("PAUSE") ;
    return 0;
 
}
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.07.2012, 01:51
Помогаю со студенческими работами здесь

Нужно написать коментарии к программе
Нужно написать коментарии к программе. #include &lt;iostream&gt; using namespace std; void main() { const int sz = 5; int a =...

Коментарии к программе. Объясните пожалуйста что выполняют функции
#include &lt;cstdlib&gt; #include &lt;iostream&gt; using namespace std; typedef struct node { int number; node *next; ...

Нужны коментарии к программе. Вывод типов переданных аргументов
#include &lt;iostream&gt; template &lt;typename T&gt; struct NameOf {}; #define DEF_TYPENAME(type) template &lt;&gt; \ struct NameOf&lt;type&gt; {\ ...

Напишите пожалуста коментарии к программе, т.е. что каждая функция означает?
Напишите пожалуста коментарии к программе, т.е. что каждая функция означает? Программа звучит так &quot;Цифры даннго трехзначного числа N...

Добавить коментарии и интерфейс к программе
Всем здравствуйте. Я в программировании на С++ новичок, лёгкую линейную программку ещё напишу, а вот объектно-ориентированное...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru