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

Как исправить программу с вводом в нее текстового файла созданного ею же?! - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Функцию, которая получает два параметра str1 и str2 типа string и возвращает позицию начала последнего появления str2 в str1 http://www.cyberforum.ru/cpp-beginners/thread873686.html
Напишите функцию rightposition, которая получает два параметра str1 и str2 типа string и возвращает позицию начала последнего появления str2 в str1. Например, rightposition (`Миссисипи`. `си`) дает значение 6. вот собственно код: #include <iostream.h> #include <string.h> #include <cmath> #include <conio.h> int main() {const int m=20;
C++ Решение задачи на алгоритмическом языке Ребятки! мне преподаватель сказала, что нужно составить алгоритм на Си++ задачи, которую я приложила вместе с темой в виде картинки, я ума не приложу как это делать, помогите пожалуйста, она ещё сказала, что потом этот алгоритм будем забивать в программу Borland, проверять на ошибки. В заранее Спасибо! Должно быть по оформлению что то типо этого Решение задачи на... http://www.cyberforum.ru/cpp-beginners/thread873684.html
C++ Выяснить, есть ли одинаковые числа в каждом из трех целочисленных неубывающих массивов
Прошу помочь,все мои варианты не работают Выяснить, есть ли одинаковые числа в каждом из трех целочисленных неубывающих массивов х ≤ ... ≤ х, у ≤ ... ≤ y, z ≤ ... ≤ z. Найти одно из таких чисел или сообщить о его отсутствии.
C++ палиндромы ошибка
Ребят, привет) мне тут нужно вывести числа -палиндромы. но проблемка в том что у меня выдает ошибку, не знаю как исправить.. подскажите? #include <vcl.h> #pragma hdrstop #include "Unit1.h" //--------------------------------------------------------------------------- #pragma package(smart_init)
C++ Сформировать одномерный массив целых чисел, используя датчик случайных чисел http://www.cyberforum.ru/cpp-beginners/thread873667.html
1)Сформировать одномерный массив целых чисел, используя датчик случайных чисел. 2)Распечатать полученный массив. 3)Перевернуть массив и, если число элементов массива нечетное, удалить его средний элемент. 4)Добавить в начало массива 3 элемента с значением M-2. 5)Распечатать полученный массив. Незнаю как сделать 3й пункт Вот что сделал: #include "stdafx.h"
C++ Нахождение палиндрома в строке Суть задачи в том, чтобы в заданной строке найти самый длинный палиндром, при чем в строке abacbaa самый длинный палиндром ababa, если есть несколько палиндромов одинаковой длины, найти любой из них. То есть из заданной строки нужно образовать максимальный по длине палиндром путем удаления какого то количества букв, при чем не нарушая порядок. Пытался сделать динамикой, но постигла неудача :((( подробнее

Показать сообщение отдельно
Chago
1 / 1 / 0
Регистрация: 20.05.2013
Сообщений: 28

Как исправить программу с вводом в нее текстового файла созданного ею же?! - C++

21.05.2013, 22:25. Просмотров 235. Ответов 1
Метки (Все метки)

Я немного повторюсь, но с прошлой проблемой разобрался.
При выводе данных из файла на экран, все данные просто повторяются пока не выйдешь из программы.

Может кто подскажет как привести программу в порядок?

Суть задания заключалось в этом:

Картотека в бюро обмена квартир организована в виде линейного списка. Сведения о каждой квартире включают:
• количество комнат;
• этаж;
• площадь;
• адрес.
Написать программу, которая обеспечивает:
• начальное формирование картотеки;
• ввод заявки на обмен;
• поиск в картотеке подходящего варианта: при равенстве количества комнат и этажа и различии площадей в пределах 10% соответствующая картотека выводится и удаляется из списка, в противном случае поступившая заявка включается в список;
• вывод всего списка.

С некоторыми пунктами справился, картотеку формирует, не получается выводить заявку на обмен и поиск по картотеке, ну а список выводит но как я писал выше его клинит)

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
#include <windows.h>
#include <string>
#include <iostream>
#include <iomanip>
#include <fstream>
using namespace std;
 
struct date
{
    int kol_kom;
    int floor;
    int plo;
    char adress[15];
      struct date *next;
 
};
 
date* cor=NULL;
 
 
int menu()
{
    int choice;
        cout<<"Menu\n"
    <<"1. Sozdat' new data base\n"
    <<"2. Schitat' iz faila\n"
    <<"3. Vivesti na ekran\n"
    <<"4. Save in file\n"
    <<"5. Sozdat' zayavku na obmen\n"
    <<"Enter your choice:   ";
 
    cin>>choice;
    return choice;
}
 
int out_file(char* filename,date* cor)  //ф-ия вывода в файл
{
    ofstream file(filename);
    if (!file)                          //проверка наличия файла
    {
        cout<<"file not found\n";             
        exit(1);
        }                             
    while (cor)                          //условие конца лин.списка
    {
        file<<cor->kol_kom<<endl;
        file<<cor->floor<<endl;
        file<<cor->plo<<endl;
        file<<cor->adress<<endl;
        cor=cor->next;
    }
    
    file.close();
 
 
        return 0;
}
 
 
date *read_baze(char *filename)         //ф-ия чтения из фала
{
    date*p=NULL;
    ifstream file(filename);
    if (!file) {cout<<"file not found\n"; exit(1);}  //Как выйти из ф-ии если нет файла?! 
    date *a=NULL;
    a=new date();
    
    while(!file.eof())
    {
 
        file>>a->kol_kom;
        file>>a->floor;
        file>>a->plo;
        file>>a->adress;
        a->next=p;
        p=a;
    }
    file.close();
    return p;
}
 
 
 
 
void out_Date(date* cor)                   //ф-ция вывода полученного списка на экран
{
    date* bz=cor;
    while(bz)
    {
        cout<<bz->kol_kom<<endl;
        cout<<bz->floor<<endl;
        cout<<bz->plo<<endl;
        cout<<bz->adress<<endl;
        bz=bz->next;
    }
}
 
void bid(date* cor)                       //ф-ция формирования заявки, поиск удоволетворяющего варианта, если нашли удаляем из
{                                         //списка подходящую, если нет добавляем в список
    int qty,stage,area;                  
    char otv[2];
    bool flag=false;
    date *buf=NULL;                       
    area=0;
    //*prev=0;
    cout<<"Vvedite dannie dlya obmena :\n";
    cout<<"Vvedite kol-vo komnat\n";
        cin>>qty;
    cout<<"Vvedite etazg\n";
        cin>>stage;
    cout<<"Vvedite ploshad'\n";
        cin>>area;
    double x=(cor->plo+area)*0.1;
    while (cor)
    {
        if ((cor->kol_kom==qty ) && (cor->floor==stage) && (cor->plo-area<=x))    //проверка заявки со списком
        {
            flag=true;
            buf=cor;
        }
    }
    if (flag)
    {
        cout<<"Vivesti podhodyashuu zayavku?"<<endl;
        cin>>otv;
        if (otv=="y")
            {
                cout<<buf->kol_kom<<endl;
                cout<<buf->floor<<endl;
            }
    }
    else
            cout<<"file not found"<<endl;
}
 
 
int main()
{
      {
            choice=menu();
    
    switch(choice)
        {
            case 1: 
                {
                    delete cor;
                    cout<<"Skol'ko elementov hotite sozdat'?"<<endl;
                        cin>>count;
                    int kol,level,S;
                    char adress[15];
                    date* ter=cor;
                    for (int i=0;i<count;i++)
                        {
                            cout<<"--------"<<i+1<<" element"<<"--------"<<endl;
                            cout<<"Vvedite kol-vo komnat :  ";
                                cin>>kol;
                            cout<<"Vvedite etazg :  ";
                                cin>>level;
                            cout<<"Vvedite ploshad' :  ";
                                cin>>S;
                            cout<<"Vvedite adres :  ";
                                cin>>adress;
                            cout<<"-------------------------------"<<endl;
                            date *bz= new date;
                             bz->kol_kom=kol;
                             bz->floor=level;
                             bz->plo=S;
                             strcpy_s(bz->adress,adress);
                             bz->next=NULL;
                            if(cor==NULL)
                                {
                                    cor=bz;
                                    ter=cor;
                                }
                            else
                                {
                                    ter->next=bz;
                                    ter=bz;
                                }
 
                        }   
            break;
                }
                case 2: cor=read_baze("baza.txt"); break;
                case 3: out_Date(cor); break;
                case 4: out_file("baza.txt",cor); break;
                case 5: bid(cor);  break;
    
    }
    
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru