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

Односвязный (двусвязный) список - поиск людей по минимальному и максимальному возрасту - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Дописать прогу Priority Queue class используя heap для хранения данных http://www.cyberforum.ru/cpp-beginners/thread842308.html
Помогите, пожалуйста, дописать программу Priority Queue class используя heap для хранения данных: мне нужно даписать все не законченные member functions of the PriorityQueue class, таким образом чтобы класс использовал heap, чтобы хранить и восстанавливать елементы. Особенно не обходимо завершить следующие функции: - PriorityQueue() - insert() - get_front() - print_tree() - is_leaf() -...
C++ комментарии к программе можно написать построчные комментарии к программе? #include <stdio.h> #include <conio.h> #include <math.h> #include <iostream.h> struct jurnal { char njurnal; char izdatel; http://www.cyberforum.ru/cpp-beginners/thread842303.html
C++ операторы if else
Здравствуйте. Только начал работать на СИ++ Написал программу Выводит ошибку. те кто с СИ++ на Ты, помогите пожалуйста
C++ Есть ли смысл в privet конструкторах и деструкторах?
Ну собственно вопрос в шапке...:)
C++ Оператор delete http://www.cyberforum.ru/cpp-beginners/thread842261.html
Вчера заметил, но ответа в сети так и не нашел: int *i = new int(5); cout << *i << endl; delete i; int p = *i; cout << p << endl; Выводит: 5 0. Но если использовать, например, массивы - то можно будет скопировать все содержимое после удаления. Что делает delete? Просто информирует систему о том, что блок памяти больше не используется?
C++ Разносторонний тупоугольный треугольник Задали задачу, не знаю как решить(. Введите 3 числа. Если они могут быть длинами сторон разностороннего тупоугольного треугольника, выведите их в порядке возрастания и вычислите площадь полученного треугольника. Помогите на С++ пожалуйста!!!!!!!!!!! подробнее

Показать сообщение отдельно
ksandro
31 / 31 / 1
Регистрация: 15.04.2011
Сообщений: 81
20.04.2013, 13:40     Односвязный (двусвязный) список - поиск людей по минимальному и максимальному возрасту
список односвязный
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
#include <iostream>
#include <fstream>
#include <ctime>
#include <cstdlib>
 
using namespace std;
 
// Формируем тип данных - структура студента
struct student 
{
    char            name[10];           // фамилия
    unsigned int    year;           // Год рождения
    char            faculty[5];        // Название факультета
    char            course;         // номер курса
    student *next; 
}
typedef StudentData;
 
int main(int argc, char* argv[])
{
    //fstream open;
    // Для текущей даты
    time_t systime;
    // Имя файла для работы
    const char* NameOfFile = "data.txt";
    // Количество найденных студентов
    unsigned int Count = 0;
    // текущий год
    unsigned int CurrYear = 0;
    // минимальный и максимальный возраст студентов для поиска
    unsigned int MinFindAge = 0;
    unsigned int MaxFindAge = 0;
    // Количество студентов
    unsigned int AllStudent = 6;
    // Объявляем массив с данными о студентах
    StudentData* StudentList = NULL;
    // если нет файла с данными
    // заполняем их с клавиатуры
    // Используя средства С++ инициализруем файлик
    fstream open(NameOfFile);
    // Проверяем наличие файла
    if (!open.fail())
    {
        unsigned int i = 0;
        // Есть файл, читаем из него
        while ((!open.eof()))
        {
            StudentData* stud = new StudentData;
            open>>stud->name;
            open>>stud->year;
            open>>stud->faculty;
            open>>stud->course;
 
            stud->next = StudentList;
            StudentList = stud;
        }
        // Закрываем файл
        open.close();
    }
    else
    {
        // нет файла, огранизуем ввод с клавиатуры
        // и формируем файл для сохранения
        ofstream out(NameOfFile);
        char yesno= 'n';
        do
        {
            StudentData* stud = new StudentData;
 
            printf("Enter name of student:\t");
            scanf("%s", &(stud->name));
            printf("Enter year of born student: \t");
            scanf("%d", &(stud->year));
            printf("Enter faculty:\t");
            scanf("%s", &(stud->faculty));
            printf("Enter course:\t");
            scanf("%d", &(stud->course));
            // сразу введенную запись сохраняем в файле для будущей работы
            out << stud->name << "\n";
            out << stud->year << "\n";
            out << stud->faculty << "\n";
            out << stud->course << "\n";
            // Очищаем экран для нового ввода
            system("cls");
 
            printf("add more students? (y/n): \t");
            scanf("%c", &yesno);
        }
        while(yesno == 'Y' || yesno == 'y');
        // Закрываем файл
        out.close();    
    }
    // задаем условия для поиска
    printf("\nEnter min - max age for students: \t");
    scanf("%d %d", &MinFindAge, &MaxFindAge);
    // Определяем текущий год
    systime = time(&systime);
    CurrYear = (gmtime(&systime)->tm_year) + 1900;
    // Делаем разделитель для результатов
    printf("\n------------------------------\n");
    // перебираем в цикле данные и смотрим общее количество
    for (StudentData* stud = StudentList; stud != NULL; stud = stud->next)
    {
        // Определяем возраст текущего студента 
        // из текущего года вычитаем год его рождения
        unsigned int CurrAge = CurrYear - stud->year;
        // смотрим, лежит ли его возраст в пределах поиска
        if ((CurrAge >= MinFindAge) && (CurrAge < MaxFindAge))
        {
            // это подходящий студент, выводим его
            printf("Find student: %s, age %d\n", stud->name, CurrAge);
            // Считаем общее количество найденных
            Count++;
        }
    }
 
    // Обработка результата общая
    printf("Result: Find %d students\n", Count);
    system("PAUSE");
    return EXIT_SUCCESS;
}
 
Текущее время: 06:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru