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

Нарисовал блок схему нужно проверить - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Сравнение одночленов X со степенями http://www.cyberforum.ru/cpp-beginners/thread611205.html
Здравствуйте. Есть задача: Дана запись многочлена (от переменной X) произвольной степени с целыми коэффициентами, причем его одночлены могут быть и не упорядочены по степеням X, а одночлены одной и той же степени могут повторяться, например: -8x^4-74x+8x^4+5-x^3 Требуется привести подобные члены в этом многочлене, после чего распечатать его по убыванию степеней X. Как я понимаю сначала...
C++ Найти целую часть суммы чисел Исходные данные: x=12 a=9,5 Найти целую часть суммы чисел G, I, U http://www.cyberforum.ru/cpp-beginners/thread611200.html
C++ Система линейных уравнений методом Гаусса с выбором главного элемента по столбцу
не как не пойму что делают в прямом ходе каждый из For #include "stdafx.h" #include <iostream>//i/o #include <conio.h> //getch #include <cmath> //fabs, abs using namespace std; void ShowVector(int n, double * vec); void PryamoiHod(int n, double **a, double *b);
C++ Статитческие анализаторы
Какой лучшией статический анализатор который можно в торренте... или наоборот мож фриварные хорошие есть подскажите плиз
C++ Вычислить значение функции http://www.cyberforum.ru/cpp-beginners/thread611160.html
Составить программу для вычесления значений функции F(x) на отрезке с шагом h(3 варианта, используя цикл с постусловием, предусловием и со счетчиком). F(x)=(1-x2)(2+x)
C++ Список: связный список, в котором информация о книгах сортируется по убыванию стоимости. Друзья помогите с реализацией списка. Нужно запрограммировать связный список, в котором информация о книгах сортируется по убыванию стоимости. подробнее

Показать сообщение отдельно
maklai
3 / 3 / 0
Регистрация: 13.04.2012
Сообщений: 58
21.06.2012, 19:09     Нарисовал блок схему нужно проверить
Рисую блок схему первый раз за 2 года..
вот код программы
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
254
255
256
257
258
259
260
261
262
263
264
265
#include <windows.h>
#include <string>
#include <iostream>
#include <iomanip>
#include <fstream>
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
using namespace std;
 
struct bure
{
    int qty;  //кол-во комнат
    int floor;  //этаж
    int area;   //площадь
    char address[15];
        bure *next;
 
};
 
typedef bure *cor;
 
int menu()    //меню
{
    int choice;
    cout<<"Меню:"<<endl;
    cout<<"1.Создать элемент\n"
        <<"2.Вывести базу на экран\n"
        <<"3.Состовление заявки\n"
        <<"4.Выход\n"
        <<"Выберите нужное действие: ";
        cin>>choice;
        if (cin.fail())
        {
            cin.clear();
            cin.ignore();
        }
        return (choice);
}
 
cor find_l(cor &start)       //нахождение послд.эл-та
{
    cor l=start;
    while(l->next)
        l=l->next;
    return l;
}
 
 
void add_first(cor &start,cor new_beg)//в начало
{
    new_beg->next=start;
    start=new_beg;
}
 
 
 
 
void add_last(cor &start,cor new_beg)//в конец
{
    cor q=start;
    if(start==NULL)
    {
        add_first(start,new_beg);
    }
 
    else
    {
        q=find_l(start);
        new_beg->next=q->next;
        q->next=new_beg;
    }
    return;
}
 
 
 
cor new_element()  //создать новый элемент
{
    char buf[15];
    cor beg=(cor)malloc(sizeof(bure));
    cout<<"-------------------\n";
    cout<<"Введите этаж: ";
    cin>>beg->floor;
    if (cin.fail())
    {
        cin.clear();
        cin.ignore();
        
    }
    cout<<"Введите площадь: ";
    cin>>beg->area;
    if (cin.fail())
    {
        cin.clear();
        cin.ignore();
    }
    cout<<"Введите кол-во комнат: ";
    cin>>beg->qty;
    if (cin.fail())
    {
        cin.clear();
        cin.ignore();
    }
    cout<<"Введите адрес: ";
    cin.ignore();
    cin.getline(buf,15);
    cout<<"-------------------\n";
    system("cls");
    strcpy_s(beg->address,buf);
    beg->next=NULL;
    return (beg);
}
 
 
void add_date(cor &start)    //добавления эл-та
{
    cor pv=new_element();
    add_last(start,pv);
}
 
 
 
 
void del(cor start,cor pv)   //удаления эл-та
{
    cor new_beg=start;
    if (new_beg==pv)
        new_beg=new_beg->next;
    else 
    {
        while(new_beg && new_beg->next!=pv)
            new_beg=new_beg->next;
        new_beg->next=pv->next;
    }
    free(pv);
}
    
 
cor find(cor start,int et,int kol,int S)   //поиск подходящей заявки
{
    cor buf=start;
    double x;
    while(buf)
    {
        x=(buf->area+S)*0.1;
        if ((buf->qty==kol) && (buf->floor==et) && (abs(buf->area-S)<x))
            return buf;
        buf=buf->next;
    }
    buf=NULL;
    return buf;
}
 
 
 
 
 
 
void print_beg(cor &beg) //Вывод всей базы на экран
{
    cor pv=beg;
    if(pv==NULL)
    {
        cout<<"Заполните базу\n";
        return;
    }
    while(pv)
    {
        cout<<"-----------------------\n";
        cout<<"Адрес: "<<pv->address<<endl;
        cout<<"Кол-во комнат: "<<pv->qty<<endl;
        cout<<"Этаж: "<<pv->floor<<endl;
        cout<<"Площадь: "<<pv->area<<endl;
        cout<<"----------------------\n";
        pv=pv->next;
    }
}
 
 
 
void bid(cor &start) //ф-ия удов-я(не удов-ия) условия
{
        
    cor pv=NULL;
    char adr[15];
    int et,kol,S;
    cout<<"Данные для оформления заявки на поиск\n";
    cout<<"Введите этаж: ";
    cin>>et;
        if (cin.fail())
    {
        cin.clear();
        cin.ignore();
        
    }
    cout<<"Введите площадь: ";
    cin>>S;
        if (cin.fail())
    {
        cin.clear();
        cin.ignore();
        
    }
    cout<<"Введите кол-во комнат: ";
    cin>>kol;
        if (cin.fail())
    {
        cin.clear();
        cin.ignore();
        
    }
    cout<<"Введите адрес: ";
    cin.ignore();
    cin.getline(adr,15);
    pv=find(start,et,kol,S);
    system("cls");
    if (pv!=NULL)
    {
        system("cls");
        cout<<"Похожий элемент найден\n";
        print_beg(pv);
        del(start,pv);
        cout<<"Элемент удален\n";
    }
    else
    {
        cout<<"Элемент не найден\n";
        cor tv=new bure;
    tv->next=NULL;
    tv->area=S;
    tv->floor=et;
    tv->qty=kol;
    strcpy_s(tv->address,adr);
    add_last(start,tv);
    cout<<"Элемент добавлен в базу\n";
    }
}
 
int main()
{
    setlocale(LC_ALL,"rus");
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    cor start=NULL;
    int choice;
    for(int i=0;i<100;i++)
     {
        choice=menu();
        if ((choice!=1) && (choice!=2) && (choice!=3) && (choice!=4))
            {   
                system("cls");
                cout<<"Вы ввели не правильный номер действия\n"
                <<"Выберите либо 1 либо 2 либо 3\n";
                choice=menu();
            }
        switch(choice)
            {
                case 1:system("cls"); add_date(start);break;
                case 2:system("cls"); print_beg(start);break;
                case 3:system("cls");bid(start);break;
                case 4: return 0;
            }
        }
}
Блок-схемы по всей программе прикрепил.
Миниатюры
Нарисовал блок схему нужно проверить   Нарисовал блок схему нужно проверить   Нарисовал блок схему нужно проверить  

Нарисовал блок схему нужно проверить   Нарисовал блок схему нужно проверить   Нарисовал блок схему нужно проверить  

Нарисовал блок схему нужно проверить  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:49. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru