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

Блок-схема - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Строки http://www.cyberforum.ru/cpp-beginners/thread610468.html
Помогите пожалуйста с программой Требования к программе. 1. Чтение данных производить из текстового файла, запись данных в текстовый файл. 2. Определение того, подходит ли слово под заданные параметры, оформить в виде функции, возвращающей значение 1 или 0. Вывести все слова (под словом понимается непустая последовательность символов, не содержащих пробелов) во введенном предложении (и их...
C++ Определить, в записи какого из двух четырехзначных чисел больше нулей Не могу понять в чём проблема, вроде правильно написал. #include "stdafx.h" #include <iostream> using namespace std; void main() {int a,i,n; cin>>n; for (i=1;i<=n;i++) cin>>a; for (i=1;i<=n;i++) http://www.cyberforum.ru/cpp-beginners/thread610452.html
Поиск слова в файле C++
есть файл с данными (test.txt), он построен так: Имя Фамилия Номер телефона Имя Фамилия Номер телефона помогите сделать так, что бы пользователь вводил к примеру фамилию, и если она есть - ему выводило строку с Именем Фамилией и Номеров телефона. заранее благодарен
Удаление элемента C++
Уважаемые программисты!!! Помогите пожалуйста, курсовая работа. Никак не могу изменить удаление элемента... Мне нужно чтобы в программе выполнялось удаление первого элемента, у меня происходит удаление последнего элемента, как изменить я не знаю. Помогите пожалуйста!!! Очень нужна ваша помощь #include<stdio.h> #include<conio.h> struct Sheet { char a; int b; int c;
C++ Описать класс, хранящий динамический массив http://www.cyberforum.ru/cpp-beginners/thread610430.html
Нужно написать простую программу: описать класс, хранящий динамический массив, два производных класса имеют по одной функции, одна из которых находит max элемент динамического массива, другая min, эта функция задана в базовом классе как виртуальная
C++ C++ закоментите код пожалуйста! Нужно по каждой строчке, в листинге, закомментировать код…. Очень нужно! Помогите! подробнее

Показать сообщение отдельно
maklai
3 / 3 / 0
Регистрация: 13.04.2012
Сообщений: 58
20.06.2012, 20:58     Блок-схема
Помогите пожалуйста сделать блок схему к программе..сам делал последний раз года 2 назад..по QBasic..
Забыл уже все)
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;
            }
        }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 01:38. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru