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

Не могу "собрать" прогу - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Перевод строки в целое число http://www.cyberforum.ru/cpp-beginners/thread618092.html
Ребята подскажите пожалуйста как перевести длинную строку ,к примеру 1234567890123456 в целое число? Это уже наверное не int уже а long получается... пытался через atol() и через sstream выдаёт неверное чило....
C++ Создание файла в указанной директории Добрый вечер. Есть задание, пользователь запускает программу из консоли с одним аргументом - именем создаваемой папки. Необходимо в этой созданной папке создать текстовый файл. Как это сделать, подскажите пожалуйста. Папку то я создал а как быть с файлом? http://www.cyberforum.ru/cpp-beginners/thread618072.html
Генератор частот. Осталось немного доработать C++
Написал программу, которая генирирует звук заданной частоты на протяжение 8 секунд. Хочу, что бы он воспроизводился пока не нажму клавишу. Примерно знаю как это реализовать (создать 2-й буфер, пока 1-й воспроизводится, 2-й заполняется и так они чередуются, вызывабются ф-й CALLBACK), но знаний пока что не хватает еще, помогиет реализовть. #include <windows.h> #include <mmsystem.h> #include...
C++ Вывод повторяющихся чисел массива и количество повторений
Добрый день. Придумал задачу, а реализовать до конца не получается. Суть вот в чём. Массив наполняется случайными числами. Программа выводит на экран повторяющиеся числа и кол-во их повторений. У меня получилось вывести на экран весь массив и напротив каждого числа кол-во повторений. А как вывести, к примеру, число 5 - повторяется 3 раза; число 59 - повторяется 9 раз и т.д.. Т.е. исключить...
C++ string into char [] http://www.cyberforum.ru/cpp-beginners/thread618046.html
Как преобразовать string s = "ololo"; в char b;
C++ Прога имитирует работу FAT на чтение как сделать чтобы программа работала на запись? Суть в чем,написал программу имитирующую работу FAT на чтение.Хотелось бы чтобы она еще работала на запись,но стандартные функции на запись не рассчитаны ну вообще никак. В доке описан принцип записи,но он нерабочий.Да и получается гкод. Может кто знает как можно реализовать подобную тему? и еще функция _stricoll() не хочет сравнивать русские имена,что делать? подробнее

Показать сообщение отдельно
Skies
0 / 0 / 0
Регистрация: 30.06.2012
Сообщений: 23
02.07.2012, 22:43  [ТС]
Функция GroupTable(); там компилятор ругается почти на все "std": "нестатическая ссылка на член должна указываться относительно заданного объекта" и почти на все "bstd": "имя за которым следует выражение "::" должно определять класс или пространство имен".

И еще в программу надо вставить вот это

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
float average_m (group *gr) // возвращает средний балл группы.
{
    int i = 0;
    float summ_gr = 0;
    student *st;
    for (i = gr -> count, st = gr -> headst; i > 0; --i, st = st -> nextst) //подсчёт суммы баллов группы.
    {
        for (int i = 0; i < 4; i++)
        {
            summ_gr += st -> marks[i];
        }
    }
    return summ_gr / (gr -> count * 4);
}
 
group* group_k(group *gr) // создаёт группу контрактников, у которых средний балл выше, чем в группе.
{
    group *gr_k = new group; // создание группы контрактников.
    gr_k -> headst = 0;
    gr_k -> count  = 0;
    gr_k -> nextgr = 0;
    
    student *st_last; // для адреса последней  структуры в группе контрактников.
    student *st;      // для перебора структур группы *gr.
    
    for ( st = gr -> headst; st != 0; st = st -> nextst) //перебор группы *gr.
    {
        if (!(st -> b)) // если контрактник, то заход.
        {
            float summ_m = 0;
            for (int i = 0; i < 4; i++) // подсчёт суммы баллов у контрактника.
            {
                summ_m += st -> marks[i];
            }
            if ((summ_m / 4) > average_m (gr)) // если средний балл выше, чем средний в группе, то заход.
            {
                if ( gr_k -> count == 0) // если заход первый, то создём первую структуру в группе
                                         // контрактников.
                {
                    st_last = new student;    // первая  структура.
                    gr_k -> headst = st_last; // запоминаем адрес первой структуры.
                    *st_last = *st;           // копируем старую структуру в первую.
                    st_last -> nextst = 0;    // первая, она же последняя, указывает на 0.
                    gr_k -> count++;          // увеличиваем счётчик сруктур в группе контрактников.
                } 
                else                          // если заход не первый.
                {
                    student *st_k = new student; // очередная структура.
                    *st_k = *st;                 // копирование старой в новую.
                    st_last -> nextst = st_k;    // предыдущая указывает на новую.
                    st_last = st_k;              // новая становится последней.
                    st_last -> nextst = 0;      // последняя указывает на 0.
                    gr_k -> count++;      // увеличиваем счётчик сруктур в группе контрактников
                } 
             }
         }
    }
    return gr_k; // указатель на структуру контрактников.
и функцию group_k()
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
group* group_k(group *gr) // создаёт группу контрактников, у которых средний балл 
                          //выше, чем в группе.
{
    group *gr_k = new group; // создание группы контрактников.
    gr_k -> headst = 0;
    gr_k -> count  = 0;
    gr_k -> nextgr = 0;
    
    student *st_last; // для адреса последней  структуры в группе контрактников.
    student *st;      // для перебора структур группы *gr.
    
    for ( st = gr -> headst; st != 0; st = st -> nextst) //перебор группы *gr.
    {
        if (!(st -> b)) // если контрактник, то заход.
        {
            float summ_m = 0;
            for (int i = 0; i < 4; i++) // подсчёт суммы баллов у контрактника.
            {
                summ_m += st -> marks[i];
            }
            if ((summ_m / 4) > average_m (gr)) // если средний балл выше, чем средний в группе, то заход.
            {
                student *add = new student;    // новая структура.
                *add = *st;           // копируем старую структуру в новую.
                add -> nextst = 0;    // дальше новой ничего.
                gr_k -> count++;      // увеличиваем счётчик сруктур в группе контрактников.
                if (gr_k -> headst == 0)  // если группа пуста.
                {
                    gr_k -> headst = add; // новая в начало группы.
                }
                else  // если группа не пуста.
                {       
                    st_last -> nextst = add; // новая в конец группы.
                }
                st_last = add;  // новая становится последней.
            } // если средний балл выше
        } // если контрактник
    } // for
    return gr_k; // указатель на структуру контрактников.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru