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

Большая задача на работу с классом и файлами

09.04.2019, 21:37. Показов 3855. Ответов 88
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
По заданию нужно:
1)Занести из файлов индекс группы студента, его фамилию, четыре оценки за экзамены и участие (0/1).
2)Начислить студентам определённой группы стипендию: все "5" и участие +50% к стипендии, без участия +25%, с четвёрками обычная стипендия, с тройками её нет.
3)Предусмотреть возможность добавления информации, удаления отдельных записей, сортировки по заданному полю.


Я и с классами, и с файлами работал очень мало, поэтому у меня возникли вопросы: как из одного файла, содержащего одновременно фамилию и, допустим, оценки, считать одно отдельно от другого? Что за возможность добавления/удаления информации, сортировка и как это сделать?

Добавлено через 4 часа 41 минуту
Пожалуйста, ответьте быстрее, мне нужно сделать эту и остальные работы как можно скорее.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.04.2019, 21:37
Ответы с готовыми решениями:

Задача на работу с файлами
Помогите решить проблему! ________________________________________ В файле находится текст программы на языке С. Создать выходной...

Задача на работу с файлами
Записать в С все положительные числа из А и В, указывая после каждого десятого элемента количество десятков. Последнее количество десятков...

Задача на работу с текстовыми файлами
В качестве входных данных поступает некоторое сообщение. Все сообщения имеют общее правило: Пользователь Команда Задача следующая. ...

88
-3 / 0 / 1
Регистрация: 29.03.2018
Сообщений: 396
20.04.2019, 20:18  [ТС]
Студворк — интернет-сервис помощи студентам
Я, видимо, не так понял. Я думал, что придётся отдельно прописывать сравнение каждой пары элементов. Я уже написал, что смогу накалякать код сравнения оценок, группы и активности, но как быть с фамилиями? Сравнивать код каждого символа? Это же очень долго.
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,536
Записей в блоге: 1
20.04.2019, 20:33
если фамилии объявлены как std::string, то их тоже можно сравнивать.
Цитата Сообщение от ChioraYaz Посмотреть сообщение
Сравнивать код каждого символа? Это же очень долго.
что же в этом долгого? Если надо сортировать по фамилии, то иначе никак. Если тебя беспокоит написание цикла сравнения строк посимвольно, то это не требуется, для строк есть оператор <, который конечно у себя внутри будет сравнивать фамилии в цикле, но это вообще не твоя забота.
0
-3 / 0 / 1
Регистрация: 29.03.2018
Сообщений: 396
20.04.2019, 20:51  [ТС]
Понял. В случае чего просто сравню первые буквы фамилии, так, скорее всего, тоже пойдёт.
Ещё сегодня я заметил, что функция удаления не работает правильно. В случае, если указано две и более фамилий для удаления, удаляется только одна. Насколько я понял, это из-за того, что в массиве фамилий для удаления после каждого удаления происходит уменьшение массива на 1, и из-за этого удалиться может не та фамилия, данные студента с которой убрали.
Если я переделаю код так, чтобы он сравнивал последний элемент этого массива со всеми элементами вектора, при совпадении удалял этот элемент массива и сравнивал вектор уже с предыдущим, идя до начала, то так программа будет работать правильно всегда?
0
-3 / 0 / 1
Регистрация: 29.03.2018
Сообщений: 396
21.04.2019, 22:39  [ТС]
C++
1
2
3
4
5
6
7
8
9
10
11
            for(int i = 0; i < st.size(); i++)
            {
                st1[i].ind=st[i].ind;
 
                st1[i].fam=st[i].fam;
 
                for (int j = 0; j < 4; ++j)
                    st1[i].oc[j]=st[i].oc[j];
 
                st1[i].uch=st[i].uch;
            }
Я правильно скопировал вектор? При попытке вывести его на экран программа просто прекращает работу.
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,536
Записей в блоге: 1
21.04.2019, 23:08
нет, перед тем как что-то копировать в вектор нужно убедиться, что он одинакового размера с твоим исходным.
простое обращение по индексу[i] не создаёт в векторе новых элементов, если их там не было до этого.
Чтобы они там были есть два способа
1) растянуть изначально пустой вектор до нужного размера, тогда в нём появятся все i-е элементы, к которым можно будет обращаться в цикле
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
st1.resize(st.size() );//теперь size у st1 ==size у st
         for(int i = 0; i < st.size(); i++)
            {
 
                st1[i].ind=st[i].ind;
 
                st1[i].fam=st[i].fam;
 
                for (int j = 0; j < 4; ++j)
                    st1[i].oc[j]=st[i].oc[j];
 
                st1[i].uch=st[i].uch;
            }
2)выполнять в цикле операцию push_back для заполняемого вектора
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
                 for(int i = 0; i < st.size(); i++)
            {
                student new_student;
                new_student.ind=st[i].ind;
 
                new_student.fam=st[i].fam;
 
                for (int j = 0; j < 4; ++j)
                    new_student.oc[j]=st[i].oc[j];
 
                new_student.uch=st[i].uch;
                st1.push_back(new_student);//не просто копирование элемента в вектор, 
                //но и одновременно расширение его размера на 1 элемент
            }
0
-3 / 0 / 1
Регистрация: 29.03.2018
Сообщений: 396
22.04.2019, 16:37  [ТС]
Первый способ сделал st1 полностью пустым, везде нули и пустые строки, у второго способа изменений не было, просто завершается программа.
0
-3 / 0 / 1
Регистрация: 29.03.2018
Сообщений: 396
25.04.2019, 15:17  [ТС]
В общем, посмотрел предикаты сортировки, решил сделать. Вот предикат для сортировки участия:
C++
1
2
3
4
bool uchSort(Student x, Student y)
{
    return x.uch<y.uch;
}
А вот код, которые сортирует, если нужна сортировка по участию:
C++
1
2
3
4
if(sortir1=='uch')
        {
            std::sort(st.begin(), st.end(), uchSort);
        }
Проблема в том, что это вообще ничего не сортирует, как было, так и остаётся. Что я неправильно сделал?
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,536
Записей в блоге: 1
25.04.2019, 17:06
Цитата Сообщение от ChioraYaz Посмотреть сообщение
if(sortir1=='uch')
что это ещё за uch в одинарных кавычках?
я на всякий случай напоминаю, что тип char хранит только одинарные символы, а не строки.
0
-3 / 0 / 1
Регистрация: 29.03.2018
Сообщений: 396
25.04.2019, 18:12  [ТС]
Вот это да, конкретная лажа, для редактирования у меня тип string, а тут я, видимо, скопировал оттуда, где просто y/n. В общем, теперь сортировка по участию работает.
По остальным полям попробую сделать аналогично.

Добавлено через 13 минут
Это было странно, но я могу сравнить элементы типа string с помощью обычного > или <, и это будет работать.
Сейчас переделаю цикл сравнения с удалением, и тогда, видимо, всё будет готово.

Добавлено через 4 минуты
Переделывать ничего и не пришлось, просто сделал так, чтобы не элементы вектора сравнивались с элементами массива фамилий для удаления, а наоборот. Теперь удаление работает как надо.

Добавлено через 27 минут
Для тех, кому понадобится решить подобную задачу, я оставлю тут полный код программы.



Кликните здесь для просмотра всего текста
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
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
#include <iostream>
#include <vector>
#include <fstream>
#include <cstring>
#include <cstdlib>
#include <algorithm>
 
using namespace std;
 
class Student
{
public:
 
    int ind;
    string fam;
    int oc[4];
    int uch;
    int stip=1500;
};
 
 
bool uchSort(Student x, Student y)
{
    return x.uch>y.uch;
}
 
 
bool famSort(Student x, Student y)
{
    return x.fam<y.fam;
}
 
 
bool ocSort(Student x, Student y)
{
    float sx=0, sy=0;
 
    sx=(x.oc[0]+x.oc[1]+x.oc[2]+x.oc[3])/4;
 
    sy=(y.oc[0]+y.oc[1]+y.oc[2]+y.oc[3])/4;
 
    return sx>sy;
}
 
 
bool indSort(Student x, Student y)
{
    return x.ind>y.ind;
}
 
 
int main()
{
    int i, j=0, v=0, p, a, kv=0;
    vector <Student> st;
    Student temp;
    char menu=' ', sortir;
    string red, famdel[100], sortir1;
 
    ifstream fi;
 
    fi.open("dannie.txt");
 
    if (!fi)
    {
        cout << "Error!" << endl;
        system("pause");
        return 0;
    }
 
    while (fi >> temp.ind)
    {
       fi >> temp.fam;
 
       for (int i = 0; i < 4; ++i)
              fi >> temp.oc[i];
 
       fi >> temp.uch;
 
       st.push_back(temp);
    }
 
    fi.close();
 
    cout<<"Nazhmite <<red>> dlya dobavleniya/udaleniya"<<endl; //Редактирование
    cin>>red;
 
if(red=="red")
{
    cout<<"Nazhmite +, chtobi dobavit"<<endl;
    cin>>menu;
 
    if (menu == '+')
    {
        menu=' ';
 
        cout<<"Kol-vo: ";cin>>kv;
 
        for(j=0;j<kv;j++)
        {
            cin >> temp.ind;
 
            cin >> temp.fam;
 
            for (int i = 0; i < 4; ++i)
              cin >> temp.oc[i];
 
            cin >> temp.uch;
 
            st.push_back(temp);
        }
 
        kv=0;
 
        cout<<endl<<endl;
    }
 
    cout<<"Nazhmite -, chtobi udalit"<<endl;
    cin>>menu;
 
    if (menu == '-')
    {
        menu=' ';
 
        for(int i = 0; i < st.size(); i++)
        {
            cout << st[i].fam << endl;
        }
 
        cout<<endl<<"Kol-vo: ";cin>>kv;
 
        for(i=0;i<kv;i++)
        {
            cin>>famdel[i];
        };
 
        for(j=0;j<kv;j++)
        {
            for (std::vector<Student>::iterator  i = st.begin(); i != st.end(); ++i)
            {
                if (i->fam == famdel[j])
                {
                st.erase(i);
                }
            }
        }
 
        kv=0;
 
        cout<<endl<<endl;
    }
}
 
    cout<<endl<<"--------------------------------"<<endl;
 
    cout<<"Otsortirovat ne zhelayete? (y/n)"<<endl;
    cin>>sortir;
 
    if(sortir=='y')
    {
        cout<<"Kak sortirovat? (fam, otc, uch, gruppa)"<<endl;
        cin>>sortir1;
 
        if(sortir1=="uch")
        {
            std::sort(st.begin(), st.end(), uchSort);
        }
 
        if(sortir1=="otc")
        {
            std::sort(st.begin(), st.end(), ocSort);
        }
 
        if(sortir1=="gruppa")
        {
            std::sort(st.begin(), st.end(), indSort);
        }
 
        if(sortir1=="fam")
        {
            std::sort(st.begin(), st.end(), famSort);
        }
    }
 
    for(i=0;i<st.size();i++)
    {
        cout << st[i].ind << endl;
 
        cout << st[i].fam << endl;
 
        for (int j = 0; j < 4; ++j)
            cout << st[i].oc[j] << ' ';
 
        cout << endl;
 
        cout << st[i].uch << endl << endl;
    }
 
    for(i=0;i<st.size();i++) //Стипендия
    {
        if (st[i].oc[0]+st[i].oc[1]+st[i].oc[2]+st[i].oc[3]==20 && st[i].uch==1)
        {
            st[i].stip*=1.5;
        }
 
        if (st[i].oc[0]+st[i].oc[1]+st[i].oc[2]+st[i].oc[3]==20 && st[i].uch==0)
        {
            st[i].stip*=1.25;
        }
 
        if (st[i].oc[0]+st[i].oc[1]+st[i].oc[2]+st[i].oc[3]<20 && st[i].oc[0]!=3 && st[i].oc[1]!=3 &&
             st[i].oc[2]!=3 && st[i].oc[3]!=3 && st[i].oc[0]+st[i].oc[1]+st[i].oc[2]+st[i].oc[3]>15)
        {
            st[i].stip*=1;
        }
 
        if (st[i].oc[0]==3 || st[i].oc[1]==3 || st[i].oc[2]==3 || st[i].oc[3]==3)
        {
            st[i].stip=0;
        }
    }
 
    cout<<endl<<endl;
 
    for(int i = 0; i < st.size(); i++)
    {
        cout<<st[i].fam<<"  poluchil: "<<st[i].stip<<endl;
    }
 
    return 0;
}


Спасибо всем, кто помогал мне с этой темой, за это время я, наверно, даже удвоил знания в C++.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.04.2019, 18:12
Помогаю со студенческими работами здесь

Переделать работу с текстовыми файлами под работу с двоичными файлами
Здравствуйте. В этой программе идёт работа с текстовыми файлами, а нужно с двоичными. Можно ли как-то переделать? #include...

Написать программу, демонстрирующую работу с классом
Создать класс квадрат, члены класса - длина стороны. Предусмотреть в классе методы вычисления и вывода сведений о фигуре – диагоналей, ...

Задача на работу с файлами
Добрый день! Помогите, пожалуйста, решить следующую задачу: &quot;Дан текстовый файл со статистикой посещения сайта за неделю. Каждая строка...

задача на работу с файлами!
Если кому-то будет не сложно...я просто ничего в файлах практически не понимаю( известные данные: название предприятий, плановый объем...

Сложная задача на работу с файлами
Считать с клавиатуры строку, выделить слова в нее входящие. Построчно записать в файл уникальные буквы, частоту встречаемости данной буквы...


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

Или воспользуйтесь поиском по форуму:
89
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru