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

Удаление объектов структуры из файла по условию - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Как подобрать последовательность 100 случайных чисел с экспоненциальным законом на C++ http://www.cyberforum.ru/cpp-beginners/thread1303293.html
Сгенерировать последовательность 100 случайных чисел с экспоненциальным законом =2. Вычислить среднее значение и дисперсию. распределения с параметром. Построить гистограмму для полученного распределения, разбив числа на 10 интервалов.
C++ Простые числа. Решето Эратосфена Здравствуйте! Нужна ваша помощь, не могу понять условие этой задачи: Даны натуральное число n, целые числа a1,.....,an. Рассмотреть отрезки последовтельности a1, ....., an ( подпоследовательности идущих подряд членов), состоящие из простых чисел. В каждом случае получить наибольшую из длин рассматриваемых отрезков. Написать нужно через функции. Тоесть сам алгоритм нахождения простых чисел я... http://www.cyberforum.ru/cpp-beginners/thread1303291.html
C++ Простое интегрирование по времени
while (t<=interval) { v=vp+((1-pa/p)*g-(9/2)*na*vp/(r*r*p))*dt; z=zp+vp*dt; v2=vp*exp(-(9/2)*na*t/(r*r*p))+((2/9)*g*(pa/p-1)*(r*r*p)/na)*(1-exp(-(9/2)*na*t/(r*r*p))); if ((t=j*dt_out)&&(z<H)) { cout<<j<<": t="<<t<<"; v="<<v<<"; v2="<<v2<<"; z="<<z<<";"<<endl;
C++ Ошибка с указателями
Похоже у меня проблема с указателями, но что то я жутко торможу и не соображу как правильно сделать. Как минимум в 44 строке ошибка. #include <stdio.h> #include <stdlib.h> #include <conio.h> #include <string.h> #include <time.h> #include <locale.h>
C++ Запись в файл. После прохода программы содержимое файла не то, что нужно http://www.cyberforum.ru/cpp-beginners/thread1303267.html
Подскажите пожалуйста в чем ошибка, мне нужно, чтобы данные, которые выводятся на экран записывались в файл, но после прохода программы в файле записано не то, что нужно. #include <conio.h> #include <iostream.h> #include <fstream.h> void main() { int a1, a2, a3; a1=a2=a3=1;
C++ Считать с файла строку и найти в ней найти самое длинное слово и самую длинную фразу Из текстового файла прочитать строку и найти в ней найти самое длинное слово и самую длинную фразу подробнее

Показать сообщение отдельно
jorjio
0 / 0 / 0
Регистрация: 22.11.2013
Сообщений: 34
17.11.2014, 19:09     Удаление объектов структуры из файла по условию
Не работает удаление! при удаление элемента происходит поиск! в итоге в поиске отоброжается -8690877374 типа такого элемента нет в массиве! но при этом удаляет нужный элемент

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
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
#include <stdafx.h>
#include <cstdlib>
#include <iostream>
#include <stdlib.h>
 
 
#include <stdio.h>
#include <conio.h>
 
 
 
#include <windows.h>
#include <fstream> 
 
using namespace std;
 
 
 
 
 
struct avto//объявление структуры
{
    char marka[20]; 
    int year;
    int id;
    float price;
    char color[20];
};
 
void create_file(int n1, avto mass1[500])//Объявление функции создания файла
 
{
    fstream datafile("datafile.txt",ios::out);
        for(int i=0;i<n1;i++)
    { 
        
        cout<<"\n"<<"введите данные о автомобиле № "<<i+1<<"\n"<<"------------------->";
        cout<<"\n"<<"Ид ="; cin>>mass1[i].id;
        cout<<"марка ="; cin>>mass1[i].marka; 
        cout<<"год выпуска = "; cin>>mass1[i].year; 
        cout<<"Цена = "; cin>>mass1[i].price; 
        cout<<"Цвет = "; cin>>mass1[i].color;
        cout<<"<-------------------\n";
    }
 
    datafile.close();//Закрытие файлового потока
 
}
 
void vivod_dann()//Объявление функции чтения файла
{
    cout<<"\n"<<"\n"<<"====================================="<<"\n"<<"Чтение файла...........\n";
    fstream datafile;
    avto pass;
    datafile.open("datafile.txt", ios::in);
    cout<<"\n";
    do//чтение файла
    {   datafile>>pass.id;
        datafile>>pass.marka; 
        datafile>>pass.year;
        datafile>>pass.price;
        datafile>>pass.color;
        
        if (datafile.eof()) break;
        cout<<"Ид          = "<<pass.id<<"\n";
        cout<<"марка       = "<<pass.marka<<"\n";
        cout<<"год выпуска = "<<pass.year<<"\n";
        cout<<"Цена        = "<<pass.price<<"\n";
        cout<<"Цвет        = "<<pass.color<<"\n";
        cout<<"==================================\n"<<"\n";     
    }
    while(!datafile.eof());
    datafile.close();
}
 
 
void vvod_dann()//Объявление функции ввода данных в файл
{
    int n1, i; avto pass;
    i=0;
    ofstream datafile("datafile.txt", ios::app);
    cout<<"Введите количество новых добовляемых элементов :"; cin>>n1;
    if(n1!=0)
    do//запись в массив
    {
        cout<<"\n";
    cout<<"Ид          = "; cin>>pass.id;
    cout<<"марка       = "; cin>>pass.marka;
    cout<<"год выпуска = "; cin>>pass.year;
    cout<<"Цена        = "; cin>>pass.price;
    cout<<"Цвет        = "; cin>>pass.color;
    
    datafile<<pass.id<<" ";
    datafile<<pass.marka<<" "; 
    datafile<<pass.year<<" ";
    datafile<<pass.price<<" ";
    datafile<<pass.color<<" ";
    datafile<<"\n";
    i++;
    }
    while(i<n1);
    datafile.close();   
}
 
 
void udal_dann()//Объявление функции поиска и удаления элементов из файла
{
//  fstream datafile("datafile.dat", ios::in);
    avto pass[50];
    int i=0; int n1=0; 
    fstream datafile;
 
    datafile.open("datafile.txt", ios::in);
    cout<<"\n";
    do//чтение файла
    {   datafile>>pass[i].id;
        datafile>>pass[i].marka; 
        datafile>>pass[i].year;
        datafile>>pass[i].price;
        datafile>>pass[i].color;
        i++; n1++;
            
    }
    while(!datafile.eof());
    datafile.close();
 
    int mk; bool check=0; int deln;
 
    cout<<"\n Введите год, для удаления \n"; cin>>mk;
 
    for(i=0;i<n1;i++)
    {   
        if(mk<pass[i].year)
        {
            deln=i;
            cout<<"\n===================================НАЙДЕНО=================================\n";
            cout<<"Ид ="<<pass[i].id<<"\nМарка="<<pass[i].marka<<"\nГод выпуска="<<pass[i].year<<"\n№Цена="<<pass[i].price<<"\nЦвет="<<pass[i].color<<"\n";
            cout<<"===========================================================================\n";
            check=1;
        };
    };
    if(check!=1)
    {
        cout<<"=============================\n";
        cout<<"Нет элементов удовлетворяющих поиску\n"<<"=============================\n";
    }
    else 
    {
        int sel;
        cout<<"Удалить данный(е) элемент(ы)?\n"<<"1. Да\n"<<"2. Нет\n"; 
        cin>>sel;
        if (sel==1)
        {
            fstream datafile("datafile.txt",ios::out);
            for(i=0;i<n1;i++)
                if(pass[i].year>mk)
                {
                    datafile<<pass[i].id<<" ";
                    datafile<<pass[i].marka<<" ";
                    datafile<<pass[i].year<<" ";
                    datafile<<pass[i].price<<" ";
                    datafile<<pass[i].color<<" ";
                    datafile<<"\n";
                }
            cout<<"элементы удалены...\n";
        }
    };  
}
 
void find_dann()//Объявление функции поиска 
{
//  fstream datafile("datafile.dat", ios::in);
    avto pass[50];
    int i=0; int n1=0; 
    fstream datafile;
 
    datafile.open("datafile.txt", ios::in);
    do//чтение файла
    {   datafile>>pass[i].id;
        datafile>>pass[i].marka; 
        datafile>>pass[i].year;
        datafile>>pass[i].price;
        datafile>>pass[i].color;
        i++; n1++;
            
    }
    while(!datafile.eof());
    datafile.close();
 
    int mk; bool check=0; int deln;
 
    cout<<"Введите ид, для поиска \n"; cin>>mk;
 
    for(i=0;i<n1;i++)
    {   
        if(mk==pass[i].id)
        {
            
            cout<<"\n===================================НАЙДЕНО=================================\n";
            cout<<"Ид ="<<pass[i].id<<"\nМарка="<<pass[i].marka<<"\nГод выпуска="<<pass[i].year<<"\n№Цена="<<pass[i].price<<"\nЦвет="<<pass[i].color<<"\n";
            cout<<"===========================================================================\n";
            check=1;
        };
    };
    if(check!=1)
    {
        cout<<"=============================\n";
        cout<<"Нет элементов удовлетворяющих поиску\n"<<"=============================\n";
    }
 
    
}
 
 
 
int main(int argc, char *argv[])
{
 
    setlocale(0, "rus");
 
    
 SetConsoleOutputCP(1251);//настройка ввода и вывода в консоли с русским шрифтом
    
    cout<<"**************************************\n";
    cout<<"*******-----База автопарка-----*******\n"; 
    cout<<"**************************************\n"; 
    int k;
 
    do
{
 
    cout<<"Для работы, введите команду:";
    cout<<"\n"<<"1. Ввод данных в файл\n";
    cout<<"2. Прочитать файл\n";
    cout<<"3. Удаление элементов по году производства из файла\n";
    cout<<"4. Поиск элемента по ид\n";
              cout<<"5. Выход\n";
    cin>>k;
    switch (k)
    {
    case 1: vvod_dann();
//      cout<<"Введите количество вводимых автомобиле: "; cin>>n; create_file(n,mass); 
         break;
    
    case 2: vivod_dann(); break;
    case 3: udal_dann(); break;
    case 4: find_dann(); 
    break;
 
    }
}
while (k!=5);
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 04:22. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru