Форум программистов, компьютерный форум 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 числа. Если они могут быть длинами сторон разностороннего тупоугольного треугольника, выведите их в порядке возрастания и вычислите площадь полученного треугольника. Помогите на С++ пожалуйста!!!!!!!!!!! подробнее

Показать сообщение отдельно
Suprastin
0 / 0 / 0
Регистрация: 14.12.2012
Сообщений: 38
19.04.2013, 10:06     Односвязный (двусвязный) список - поиск людей по минимальному и максимальному возрасту
Здравствуйте форумчане. Имеется задание: Для структуры из Вашего варианта работы 6 сформировать динамический односвязный или двусвязный список. В наличие задача в которой происходит поиск людей по минимальному и максимальному возрасту - введенному с клавиатуры.
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
#include <iostream>
#include <fstream>
#include <windows.h>
 
 
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;
    // Для текущей даты
    SYSTEMTIME systime;
    // Имя файла для работы
    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 StudentArray[AllStudent];
    // если нет файла с данными
    // заполняем их с клавиатуры
    // Используя средства С++ инициализруем файлик
    fstream open(NameOfFile);
    // Проверяем наличие файла
    if (!open.fail())
    {
        unsigned int i = 0;
        // Есть файл, читаем из него
        while ((!open.eof()) && (i < AllStudent))
        {
            open>>StudentArray[i].name;
            open>>StudentArray[i].year;
            open>>StudentArray[i].faculty;
            open>>StudentArray[i].course;
            i++; 
        }
        // Закрываем файл
        open.close();
    }
    else
    {
        // нет файла, огранизуем ввод с клавиатуры
        // и формируем файл для сохранения
        ofstream out(NameOfFile);
        for (int i = 0; i < AllStudent; i++)
        {
            printf("Enter name of student:\t");
            scanf("%s", StudentArray[i].name);
            printf("Enter year of born student: \t");
            scanf("%d", &StudentArray[i].year);
            printf("Enter faculty:\t");
            scanf("%s", StudentArray[i].faculty);
            printf("Enter course:\t");
            scanf("%d", &StudentArray[i].course);
            // сразу введенную запись сохраняем в файле для будущей работы
            out << StudentArray[i].name << "\n";
            out << StudentArray[i].year << "\n";
            out << StudentArray[i].faculty << "\n";
            out << StudentArray[i].course << "\n";
            // Очищаем экран для нового ввода
            system("cls");
        }
        // Закрываем файл
        out.close();    
    }
    // задаем условия для поиска
    printf("\nEnter min - max age for students: \t");
    scanf("%d %d", &MinFindAge, &MaxFindAge);
    // Определяем текущий год
    GetLocalTime(&systime);
    CurrYear = (unsigned int)systime.wYear;
    // Делаем разделитель для результатов
    printf("\n------------------------------\n");
    // перебираем в цикле данные и смотрим общее количество
    for (int i = 0; i < AllStudent; i++)
    {
        // Определяем возраст текущего студента 
        // из текущего года вычитаем год его рождения
        unsigned int CurrAge = CurrYear - StudentArray[i].year;
        // смотрим, лежит ли его возраст в пределах поиска
        if ((CurrAge >= MinFindAge) && (CurrAge < MaxFindAge))
        {
            // это подходящий студент, выводим его
            printf("Find student: %s, age %d\n", StudentArray[i].name, CurrAge);
            // Считаем общее количество найденных
            Count++;
        }
    }
    // Обработка результата общая
    printf("Result: Find %d students\n", Count);
    system("PAUSE");
    return EXIT_SUCCESS;
}

А так же мой неудачные попытки ее сделать. Программа не выдает ошибок но и работать тоже не хочет.
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
#include <iostream>
#include <fstream>
#include <windows.h>
 
 
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;
    // Для текущей даты
    SYSTEMTIME systime;
    // Имя файла для работы
    char* NameOfFile = "data.txt";
    // Количество найденных студентов
    unsigned int Count = 0;
    // текущий год
    unsigned int CurrYear = 0;
    // минимальный и максимальный возраст студентов для поиска
    unsigned int MinFindAge = 0;
    unsigned int MaxFindAge = 0;
    // Количество студентов
    unsigned int AllStudent = 6;
    FILE *f=fopen("data.txt","rt");
 if (f==NULL) { printf ("\nCan't open data.txt");
  exit (1);   }
    student *group,*head; int count=0;
 group=(student *)malloc(sizeof(student));
 head=group;
    printf("\nEnter min - max age for students: \t");
    scanf("%d %d", &MinFindAge, &MaxFindAge); 
 group->next=NULL; printf ("\nStudents:");
 while (1) {
  fscanf (f,"/n%s %d %s %c",&head->name,head->year, &head->faculty, head->course);
    
       // Определяем текущий год
    GetLocalTime(&systime);
    CurrYear = (unsigned int)systime.wYear;
    // Делаем разделитель для результатов
    printf("\n------------------------------\n");
    // перебираем в цикле данные и смотрим общее количество
    for (int i = 0; i < AllStudent; i++)
    {
        // Определяем возраст текущего студента 
        // из текущего года вычитаем год его рождения
        unsigned int Studage = CurrYear - group->year;
        // смотрим, лежит ли его возраст в пределах поиска
    
  if ((Studage >= MinFindAge) && (Studage < MaxFindAge))
        {
            // это подходящий студент, выводим его
            printf("Find student: %s, age %d\n", group->name, Studage);
            // Считаем общее количество найденных
            Count++;
       }
}
  if (feof(f)) break;
  student *newstudent = (student *)malloc(sizeof(student));
  if (newstudent==NULL) { /* нет памяти */ }
  group->next = newstudent;
  newstudent->next = NULL;
  group = newstudent; 
 } 
 fclose(f);
 
 
    // Обработка результата общая
    printf("Result: Find %d students\n", Count);
    system("PAUSE");
    return EXIT_SUCCESS;
}

Вообщем помогите кто чем может =)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 20:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru