19 / 20 / 0
Регистрация: 09.01.2013
Сообщений: 168

Не могу найти ошибку

06.02.2013, 18:38. Показов 696. Ответов 14
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем здравствуйте. Я являюсь болельщиком Ф1, и решил написать простенькую программку, которая бы суммировала очки за гонку и записывала бы их в файл, но записывается почему-то только одно последнее значение. Помогите найти ошибку

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
#include <iostream>
#include <fstream>
#include <vector>
#include <string>
#include <windows>
 
using namespace std;
 
char bufRus[256];
 
char* Rus(const char* text) 
      {
      CharToOem(text, bufRus);
      return bufRus;
      }
 
class Formula
{
    public:
    int numberofpoints;
    string name;
    string surname;
    string team;
    string car;
};
 
Formula t;
 
int main ()
{
    fstream f;
    f.open ("inf.txt", fstream :: in); //открытие файла с информацией о гонщиках
    ifstream ("inf.txt");
    
    vector <Formula> drivers;
    
    while (true) //считывание инфы
    {   
        f >> t.name;
        f >> t.surname;
        f >> t.team;
        f >> t.car;
        
        if (f.eof())
        break;
 
        drivers.push_back (t); //запись в Вектор
    }
    f.close (); //закрытие файла
    
    int numbers [25];
    
    for (int i = 0; i < drivers.size (); ++i) //ввод очков за последнюю гонку
        {
        cout<<Rus("Введите очки ");
        cout<< drivers [i].name <<" "<< drivers [i].surname<<": ";
        cin >> numbers [i];
        }
    
    fstream k;
    k.open ("points.txt", fstream :: in | fstream :: out); //открытие файла с очками
    
    while (true)
        {
        k >> t.numberofpoints; //считывание очков, которые уже есть
        
        if (k.eof ())
        break;
        
        drivers.push_back (t);
        }
    
    for (int j = 0; j < drivers.size (); ++j)
        {
        drivers [j].numberofpoints += numbers [j]; //прибавление очков за последнюю гонку
        ofstream g ("points.txt");
        g << drivers [j].numberofpoints; //запись новой суммы очков
        
        if (g.eof ())
        break;
        }
    
    for (int h = 0; h < drivers.size (); ++h) //вывод на экран
        {
            cout<<endl;
            cout<< drivers [h].name <<" "<<drivers [h].surname<<" "<<drivers [h]. team<<" " <<drivers [h].car<<" "<< drivers [h].numberofpoints<<Rus (" очков");
            cout<<endl<<endl;
        }
        
        f.close(); //закрытие файла
}
Заранее спасибо
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.02.2013, 18:38
Ответы с готовыми решениями:

Найти слова, повторяющиеся более одного раза, не могу найти ошибку
#include &lt;iostream&gt; using namespace std; void obr1(char **s, char **mas, int n, int m) { int i; int k; char *tm; for(i...

Массивы. Посчитать количество положительных, найти минимальное, удалить строку с минимальным (Не могу найти ошибку)
// Заданы матрицы X(8;4),Y(5;5),Z(6;9). // Для каждой из матриц определить строку, в которой находится наименьшее // количество...

Не могу найти ошибку
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; #include &lt;iomanip&gt; using namespace std; int _tmain() { ...

14
381 / 352 / 113
Регистрация: 17.05.2012
Сообщений: 1,049
06.02.2013, 19:05
скорее всего потому, что тут:

C++
1
2
ofstream g ("points.txt");
g << drivers [j].numberofpoints; //запись новой суммы очков
идет запись друг на друга, если сделать так:

C++
1
ofstream g ("points.txt", ios::app)
то должно заработать
1
19 / 20 / 0
Регистрация: 09.01.2013
Сообщений: 168
06.02.2013, 19:47  [ТС]
Это не совсем то: программа просто записывает новые очки после старых, а не заменяет их
0
381 / 352 / 113
Регистрация: 17.05.2012
Сообщений: 1,049
06.02.2013, 20:09
тогда только брать удалять все и перезаписывать с новыми значениями... или делать файл произвольного доступа...

Добавлено через 3 минуты
Ryabchik, так, вы хотите чтобы в результате в файл записывалось:
имя, фамилия, команда, машина и тут очки, например, 12 13 14 15 и так по мере добавления в конец записывались еще очки, так?
0
19 / 20 / 0
Регистрация: 09.01.2013
Сообщений: 168
06.02.2013, 21:08  [ТС]
Не совсем так. Данные гонщика в одном файле, а очки в другом. Первоначально очки по нулям. Затем я ввожу в программу новые, они прибавляются к тому, что уже есть и записываются обратно вместо тех, которые были.

А что такое файл произвольного доступа?
0
381 / 352 / 113
Регистрация: 17.05.2012
Сообщений: 1,049
06.02.2013, 21:17
Ryabchik, так, ну так в чем проблема? записали данные о гонщиках в файл, затем опят считали, добавили очки и перезаписали
0
19 / 20 / 0
Регистрация: 09.01.2013
Сообщений: 168
06.02.2013, 21:27  [ТС]
Вы же видели код. Перезаписывается только последнее значение
0
381 / 352 / 113
Регистрация: 17.05.2012
Сообщений: 1,049
06.02.2013, 21:28
Ryabchik, вот посмотрите, то или нет:

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
// up.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <iostream>
#include <fstream>
#include <vector>
#include <string>
#include <locale.h>
using namespace std;
 
class Formula
{
    public:
    int numberofpoints;
    string name;
    string surname;
    string team;
    string car;
};
 
 Formula t;
int main ()
{
    wcin.imbue(locale(".866"));
    wcout.imbue(locale(".866"));
 
    fstream f;
    f.open ("inf.txt", fstream :: in); //открытие файла с информацией о гонщиках
    ifstream ("inf.txt");
    
    vector <Formula> drivers;
    
    while (true) //считывание инфы
    {   
        f >> t.name;
        f >> t.surname;
        f >> t.team;
        f >> t.car;
        
        if (f.eof())
        break;
 
        drivers.push_back (t); //запись в Вектор
    }
    f.close (); //закрытие файла
    
    int numbers [25];
    
    for (int i = 0; i < drivers.size (); ++i) //ввод очков за последнюю гонку
        {
        wcout<<L"Введите очки ";
        cout<< drivers [i].name <<" "<< drivers [i].surname<<": ";
        cin >> numbers [i];
        }
    
    fstream k;
    k.open ("points.txt", fstream :: in); //открытие файла с очками
    
    while (true)
        {
            for (int i = 0; i < drivers.size (); ++i)
            {
                 k >> drivers [i].numberofpoints; //считывание очков, которые уже есть
            }
        
        if (k.eof ())
        break;
        }
    
    ofstream g1("points.txt", ios::out);
    g1.close();
    for (int j = 0; j < drivers.size (); ++j)
        {
            
        drivers [j].numberofpoints += numbers [j]; //прибавление очков за последнюю гонку
        ofstream g ("points.txt", ios::app);
        g << drivers [j].numberofpoints << "\n"; //запись новой суммы очков
        
        }
    k.close();
    
    for (int h = 0; h < drivers.size (); ++h) //вывод на экран
        {
            cout<<endl;
            cout<< drivers [h].name <<" "<<drivers [h].surname<<" "<<
                drivers [h]. team<<" " <<drivers [h].car<<" "<< 
                drivers [h].numberofpoints;
            wcout << L" очков";
            cout<<endl<<endl;
        }
        
        f.close(); //закрытие файла
}
0
19 / 20 / 0
Регистрация: 09.01.2013
Сообщений: 168
06.02.2013, 21:35  [ТС]
Цитата Сообщение от yoghurt92 Посмотреть сообщение
#include "stdafx.h"
Компилятор протестует: [Error] E2209 Unable to open include file 'stdafx.h'

Добавлено через 37 секунд
Цитата Сообщение от yoghurt92 Посмотреть сообщение
wcin.imbue(locale(".866"));
* * wcout.imbue(locale(".866"));
И если не секрет, что это?
0
381 / 352 / 113
Регистрация: 17.05.2012
Сообщений: 1,049
06.02.2013, 21:38
тогда уберите директиву, это для работы с юникод строками
1
19 / 20 / 0
Регистрация: 09.01.2013
Сообщений: 168
06.02.2013, 21:38  [ТС]
Я убрал тот странный include, все прекрасно работает. Но меня настораживает надпись: Abnormal program termination
0
381 / 352 / 113
Регистрация: 17.05.2012
Сообщений: 1,049
06.02.2013, 21:39
где она выскакивает?
0
19 / 20 / 0
Регистрация: 09.01.2013
Сообщений: 168
06.02.2013, 21:42  [ТС]
Перед "Для продолжения нажмите любую клавишу". И еще:это такой русификатор с locale.h?
0
381 / 352 / 113
Регистрация: 17.05.2012
Сообщений: 1,049
06.02.2013, 21:44
нет, это для работы с wcin.imbue(locale(".866"));
0
19 / 20 / 0
Регистрация: 09.01.2013
Сообщений: 168
06.02.2013, 22:06  [ТС]
Спасибо большое, все работает
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.02.2013, 22:06
Помогаю со студенческими работами здесь

Не могу найти ошибку
Помогите найти ошибку: #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;string&gt; #include &lt;fstream&gt; using namespace std; ...

Не могу найти ошибку!
Вобщем вот программа. #include &lt;iostream.h&gt; #include &lt;math.h&gt; #include &lt;iomanip.h&gt; #include &lt;conio.h&gt; int main () { ...

С++ не могу найти ошибку
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; typedef double TMatrix; typedef double TVector; const int N=10; ...

Не могу найти ошибку
Всем добрый день! Уже второй день бьюсь над одной ошибкой и никак не могу найти ее. Вот отрезок кода. Сразу поясняю: нужно построить...

Не могу найти ошибку
Вот сама задача: Создайте свою версию библиотечной функции strcmp(s1, s2), которая срав¬нивает две строки и возвращает -1, если s1 идет...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Опции темы

Новые блоги и статьи
Динамические массивы в C++ - создание и использование
NullReferenced 27.04.2025
Динамические массивы представляют собой один из фундаментальных инструментов программирования на C++, позволяющий создавать структуры данных, размер которых определяется во время выполнения. . .
Асинхронный JavaScript: Промисы, Async/Await и Fetch API
Reangularity 27.04.2025
Пользователь заходит на веб-страницу, нажимает кнопку и. . . ничего не происходит. Сайт словно замер. Через несколько секунд всё внезапно оживает, но пользователь уже успел закрыть вкладку. Знакомая. . .
Management on GitLab and repository management in Visual Studio code
jigi33 27.04.2025
- repo management on GitLab - CI/ CD in GitLab - VCS repository management in Visual Studio code (see attachments)
Kanban или Scrum - что выбрать?
EggHead 27.04.2025
Kanban и Scrum — уже много лет удерживают лидирующие позиции среди гибких подходов. Руководители проектов и команды разработчиков то и дело сталкиваются с дилеммой: какой из этих двух методов выбрать. . .
Кастомные Middleware на C# в ASP.NET Core
UnmanagedCoder 27.04.2025
Разработка веб-приложений сегодня мало напоминает монолитное программирование прошлых лет. На смену громоздким блокам кода пришла модульная архитектура, где каждый компонент выполняет строго. . .
Анализ и линтинг кода JavaScript: ESLint, Prettier и JSHint
run.dev 26.04.2025
JavaScript прошёл долгий путь от простого языка для анимации веб-страниц до основы современной веб-разработки. С ростом сложности приложений, увеличением кодовых баз и масштабированием команд. . .
Паттерны в Python: Singleton, Factory и Observer
py-thonny 26.04.2025
Паттерны проектирования — это проверенные временем решения типовых проблем разработки программного обеспечения. Их история берёт начало с книги "Приёмы объектно-ориентированного проектирования. . . .
Исключения в C#: Stack Overflow, Access Violation и Out of memory
stackOverflow 26.04.2025
Исключения в C# — это не только механизм оповещения о проблемах, а целое искусство управления потоком выполнения программы в экстремальных ситуациях. Обычное исключение, например,. . .
Логирование в C# ASP.NET Core с помощью Serilog, ElasticSearch, Kibana
stackOverflow 25.04.2025
Помните те времена, когда для анализа проблемы приходилось подключаться к серверу, искать нужный лог-файл среди десятков других и вручную фильтровать тысячи строк в поисках ошибки? К счастью, эти дни. . .
Структура "железный OnKeyUp" вместо антидребезга. Полностью асинхронный счётчик.
Hrethgir 25.04.2025
Программа для симуляции схемы - Logisim Evolution В общем какое-то время отвлёкся, так было надо, теперь когда запилю это на verilog и FPGA , досоставлю заявку в ФИПС на полезную модель - не готов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru