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

Избавление от структуры - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ не могу понять принцип сортировки по командам http://www.cyberforum.ru/cpp-beginners/thread863952.html
Группа людей состоит из N членов. У каждого члена группы есть друзья в этой группе, один или более. Напишите программу, которая разделит группу на две команды. Каждый член каждой команды должен иметь друзей в другой команде. Исходные данные Первая строка ввода содержит одно число N (N ≤ 100). Члены группы занумерованы от 1 до N. Вторая, третья, …, (N+1)-я строки содержат список друзей первого,...
C++ Любая программа на с++, которая вносит изменения в регистр У меня есть скрипт vbs ,который вносит изменения в регистр,а именно создает в регистре каталог и удаляет. Можно ли сделать такое,или что то подобное на с++. Вот код set WSHShell = WScript.CreateObject("WScript.Shell") WSHShell.Popup "Создаем раздел" WSHShell.RegWrite "HKCU\MyRegKey\", "Primer" WSHShell.Popup "Создаем строковый параметр" WSHShell.RegWrite "HKCU\MyRegKey\String", 1... http://www.cyberforum.ru/cpp-beginners/thread863945.html
из паскаля в c++ C++
вот программы помогите переделать в с++ {Program101l.Решает следующую задачу: По данным значениям аргументов a,b вычислить значение функции f(a,b). При организации вычисления необходимо выявить сходные по своей схеме последовательности операций, различающихся лишь операндами, и представить их в ввиде отдельных функций. Аргументы должны принадлежать области определения функции:...
C++ Связный список; удаление равных максимальному элементов
считать числа в связный список, найти макс. элемент, удалить из списка все элементы, равные максимальному. #include <iostream> using namespace std; struct Node { int data; Node *next; Node *prev;
C++ не запускается программа http://www.cyberforum.ru/cpp-beginners/thread863926.html
Здравствуйте. Подскажите пожалуйста, из-за чего она не запускается. Заранее спасибо.
C++ Задача (вывести длину кратчайшего пути от точки до точки.) Пишу задачу, нужно вывести длину кратчайшего пути от точки до точки. проблема в том, что после генерации массива и задания ему значений, значения теряются и изменяются все на "-842150451" помогите решить проблему //файл "main.cpp" #include "Cell.h" #include "Field.h" подробнее

Показать сообщение отдельно
Suprastin
0 / 0 / 0
Регистрация: 14.12.2012
Сообщений: 38
13.05.2013, 21:23     Избавление от структуры
Всем привет. Имеется задачка выполненная с использованием классов.
Вводится ограничения по возрасту и из данного введенного промежутка выводятся люди, подходящие по критериям.
Собственно не знаю как избавиться от структуры student, так как те же поля повторяются в классе.

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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
#include <iostream>
#include <fstream>
#include <string.h>
#include <windows.h>
 
 
using namespace std;
 
// Формируем тип данных - структура студента
 
struct student 
{
    char            name[10];           // фамилия
    unsigned int    year;           // Год рождения
    char            faculty[5];        // Название факультета
    char            course;         // номер курса
    student *next; 
}
typedef StudentData;
class studentlist
{
public:
    studentlist();
    studentlist(StudentData st);
    ~studentlist();
    char *getName();
    void setName(char *str);
    unsigned int getYear();
    void setYear(unsigned int year);
    char *getFaculty();
    void setFaculty(char *strr);
    char getCourse();
    void setCourse(char course);
    int readfile(char *fname);
    void printlist(int MinAge, int MaxAge);
protected:
    char            name[10];           // фамилия
    unsigned int    year;           // Год рождения
    char            faculty[5];         // Название факультета
    char            course;         // номер курса
    studentlist *next;
};
studentlist::studentlist()
{
    this->next = NULL;
}
studentlist::studentlist(StudentData st)
{
    /*if (strlen(st.name) > 0)
        strcpy(this->name, st.name);*/
    this->setName(st.name);
    this->year = st.year;
    if (strlen(st.faculty) > 0)
        strcpy(this->faculty, st.faculty);
    this->course = st.course;
    this->next = NULL;
}
 
char *studentlist::getName()
{
    if (strlen(this->name) == 0)
        return NULL;
 
    char *str = new char[strlen(this->name)];
    strcpy(str, this->name);
    return str;
}
 
void studentlist::setName(char *str)
{
  if (str == NULL || strlen(str) == 0)
    return;
 
  strcpy(this->name, str);
  this->name[strlen(this->name)] = '\0';
  return;
 
}
unsigned int studentlist::getYear()
{
    return this->year;
}
void studentlist::setYear(unsigned int year)
{
  if (year < 1990)
    return;
  this->year = year;
  return;
 
}
char *studentlist::getFaculty()
{
 
    if (strlen(this->faculty) == 0)
        return NULL;
 
    char *strr = new char[strlen(this->faculty)];
    strcpy(strr, this->faculty);
    return strr;
}
void studentlist::setFaculty(char *strr)
{
    if (strr == NULL || strlen(strr) == 0)
    return;
 
    strcpy(this->faculty, strr);
    this->faculty[strlen(this->faculty)] = '\0';
    return;
}
char studentlist::getCourse()
{
    return this->course;
}
void studentlist::setCourse(char course)
{
    if (course < '1' || course > '6')
    return;
 
    this->course = course;
    return;
}
 
int studentlist::readfile(char *fname)
{
 
    unsigned int AllStudent = 6;
    StudentData buf;
    studentlist *tekushiy = NULL;
    fstream open(fname);
    if (!open.fail())
    {
        unsigned int i = 0;
        while ((!open.eof()) && (i < AllStudent))
        {
 
            open>>buf.name;
            open>>buf.year;
            open>>buf.faculty;
            open>>buf.course;
 
            studentlist *stud = new studentlist(buf);
            if (tekushiy == NULL)
            {
                this->next = stud;
                tekushiy = stud;
            }
            else
            {
                tekushiy->next = stud;
                tekushiy = stud;
            }
}
            open.close();
       
    }
}
 
void studentlist::printlist(int MinAge, int MaxAge)
{
    SYSTEMTIME systime;
 
    GetLocalTime(&systime);
    unsigned int CurrYear = (unsigned int) systime.wYear;
        unsigned int count = 0;
    studentlist *pos = this->next;
    while (pos!=NULL)
    {
        unsigned int CurrAge = CurrYear - pos->year;
        if ((CurrAge >= MinAge) && (CurrAge < MaxAge))
        {
            cout << pos->name << ' ' <<pos->year<<"\n";
            count++;
        }
        pos = pos->next;
    }           
     printf("Result: Find %d students\n", count);
}
 
studentlist::~studentlist()
{
   
}
 
int main(int argc, char* argv[])
{
    unsigned int MinFindAge = 0;
    unsigned int MaxFindAge = 0;
    char* NameOfFile = "data.txt";
        // задаем условия для поиска
    printf("\nEnter min - max age for students: \t");
    scanf("%d %d", &MinFindAge, &MaxFindAge);
    studentlist ST;
    ST.readfile(NameOfFile);
    ST.printlist(MinFindAge, MaxFindAge);
    system("PAUSE");
    return EXIT_SUCCESS;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 16:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru