0 / 0 / 0
Регистрация: 05.12.2011
Сообщений: 37
1

Помогите переписать программу из Visual C++ в Borland C++

29.02.2012, 22:49. Показов 556. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
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
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
#include "stdio.h"
#include "conio.h"
#include "windows.h"
#include <locale>
 
#define OUTPUT_FILE "./OUTPUT.TXT"
#define STRUCT_FILE "./STRUCT.DAT"
 
struct info
{
    int id;
    char key1[100];
    char key2[100];
    char key3[100];
    char key4[100];
};
 
struct node
{
    info har;
    node *next;
};
 
node *first, *last, *list, *addM;
 
int n;
 
void Input()
{
    char* key = new char;// перменная в которую будет записываться клавиша для продолжения ввода данных
    
    system("cls");// очистка экрана    
    printf ("** ВВОД ДАННЫХ: ** \n");
 
// проверка,есть ил уже введеные данные, тогда указатель first не будет пустой
    if (first!=NULL) {
        printf("\nОшибка! Данные уже введены.");
        getch();// ожидание нажатия клавиши
        return;
    }
//  выделяем память под 1 запись и увеличиваем счетчик записей на +1
 
    n = 1;// выделяем память под 1 запись
    first = new node;// запись адресса первого элемента
    (*first).har.id = n;//присваиваем ключу id номер
 
// вводим данные
    printf ("\nВведите название: ");
    scanf ("%s", (*first).har.key1);
    printf ("\nВведие модель: ");
    scanf ("%s", (*first).har.key2);
    printf ("\nВведите в наличии: ");
    scanf ("%s", (*first).har.key3);
    printf ("\nВведите стоимость: ");
    scanf ("%s", (*first).har.key4);
 
 
    first->next = NULL;// указателю на след. эл присвоить 0
    last = first; // last  присвоить  адресс  first
 
    while (true) {
        printf ("\nПродолжить? (Нажмите Y) ");
        scanf("%s", key);
        if (*key!='y' && *key!='Y')// if  не нажали кнопку y то прекратить функцию
            return;
        
        system("cls");// очистка экрана
        printf ("** ВВОД ДАННЫХ: ** \n");
 
 
        n++;
        list = new node;
        (*list).har.id = n;
 
 
        printf ("\nВведите название: ");
        scanf ("%s", (*list).har.key1);
        printf ("\nВведие Модель: ");
        scanf ("%s", (*list).har.key2);
        printf ("\nВведите В наличии: ");
        scanf ("%s", (*list).har.key3);
        printf ("\nВведите Стоимость: ");
        scanf ("%s", (*list).har.key4);
 
        list->next = NULL;
        last->next = list;// присвоение текущего элемента  указателю на последний эл
        last = list;
    }
}
 
void Output()
{
    // File init
    FILE *fil;
    fil = fopen(OUTPUT_FILE, "w");
    fseek(fil, 0, SEEK_SET);
 
    // UI
    system("cls");
    printf("+--------------------------------------------------------------+\n");
    printf("| # | Название | Модель | В наличии | Стоимость |\n");
    printf("+--------------------------------------------------------------+\n");
    fprintf(fil, "+-------------------------------------------------------------+\n");
    fprintf(fil, "| # | Название | Модель | В наличии| Стоимость |\n");
    fprintf(fil, "+-------------------------------------------------------------+\n");
 
    list = first;
    while (list) {
        printf("| %d |  %s  |  %s  |  %s  |  %s  \n", (*list).har.id, (*list).har.key1, (*list).har.key2, (*list).har.key3, (*list).har.key4);
        fprintf(fil, "| %d |  %s  |  %s  |  %s  |  %s  \n", (*list).har.id, (*list).har.key1, (*list).har.key2, (*list).har.key3, (*list).har.key4);
        // Merge
        list = list->next;
    }
    
    printf("+--------------------------------------------------------------+\n");
    fprintf(fil, "+-------------------------------------------------------------+\n");
 
    // File close
    fclose(fil);
 
    getch();
}
 
void Del()
{
    list=first;
    first=list->next;
    delete list;
        
    printf("\nПервая запись удалена.");
    getch();
}
 
void StructSave()
{
    FILE *fil;
    
    fil = fopen(STRUCT_FILE, "w+b");    
    fseek(fil, 0, SEEK_END);
    
    list = first;
    while (list) {
        fwrite(list, sizeof(info), 1, fil);
        list = list->next;
    }
    
    fclose(fil);
}
 
void Swap()
{
    char str1[100], str2[100];
    node *a1, *a2;
    info haract;
 
    // UI
    system("cls");
    printf ("** ОБМЕН: ** \n");
 
    printf("Введите первый ключ для обмена:\n");
    scanf("%s", &str1);
    printf("Введите второй ключ для обмена:\n");
    scanf("%s", &str2);
 
    list = first;
    while (list) {
        if (strcmp((*list).har.key1, str1)==NULL) {
            a1 = list;
        }
        if (strcmp((*list).har.key1, str2)==NULL) {
            a2 = list;
        }
        list = (*list).next;
    }
 
    haract = (*a1).har;
    (*a1).har = (*a2).har;
    (*a2).har = haract;
    
    printf("\nOK!");
    getch();
}
 
void StructLoad()
{
    FILE *fil;
    info h;
    int res;
    
    fil = fopen (STRUCT_FILE, "r+b");
    if (!fil) {
        printf("\nОшибка! Файл со структурой не существует! Загрузка невозможна.");
        getch();
        return;
    }
 
    fseek (fil, 0, SEEK_SET);
    res = fread (&h, sizeof(info), 1, fil);
    if (res == 1) {
        first = new node;
        (*first).har = h;
        first ->next = NULL;
        last = first;
    } 
 
    do {
        res = fread (&h, sizeof(info), 1, fil);
        if (res == 1){
            list = new node;
            (*list).har = h;
            list->next = NULL;
            last->next = list;
            last=list;
        }
    }
    while (res == 1);
 
    fclose(fil);
 
    getch();
}
void Add()
{
    int cur3;
 
    // UI
    system("cls");
    printf ("** ДОБАВИТЬ ЗАПИСЬ: ** \n");
 
    printf("\nВведите номер записи, после которого нужно добавить данные: ");
    scanf("%d", &cur3);
 
    // Jmp
    last = first;
    for (int j=0; j<cur3-1; j++)
        last = last->next;
 
 
    // Allocate
    n++;
    list = new node;
    (*list).har.id=n;   
 
    // UI
    printf ("\nВведите название: ");
    scanf ("%s", (*list).har.key1);
    printf ("\nВведие модель: ");
    scanf ("%s", (*list).har.key2);
    printf ("\nВведите в наличии: ");
    scanf ("%s", (*list).har.key3);
    printf ("\nВведите стоимость: ");
    scanf ("%s", (*list).har.key4);
 
    list->next=last->next;
    last->next=list;
 
    printf ("Хорошо!\n");
    getch();
}
 
void main()
{
    char globalKey;
    
    SetConsoleCP(866);
    SetConsoleOutputCP(866);
    setlocale(LC_ALL, "russian_russia.1251");
 
 
    while (true) {
        // UI
        system("cls");
        printf("+-----------------------------------------------------------------------------+\n");
        printf("+- ГЛАВНОЕ МЕНЮ -   Бытовая техника   - - - - - - - - - - - - - - - - - - - - +\n");
        printf("+-----------------------------------------------------------------------------+\n");
        printf("| F1 Ввод - F2 Вывод - F3 Загрузка - F4 Сохранение - F5 Добавить - F6 Удалить - F7 Обмен |\n");
        printf("+-----------------------------------------------------------------------------+\n");
        printf("| ESC. Выход                                                                  |\n");
        printf("+-----------------------------------------------------------------------------+\n");
 
        // Menu switch
        globalKey = getch();
        switch (globalKey)
        {
            case 59:
                Input();
                break;
            case 60:
                Output();
                break;
            case 61:
                StructLoad();
                break;
            case 62:
                StructSave();
                break;
            case 63:
                Add();
                break;
            case 64:
                Del();
            case 65:
                Swap();
                break;
            case 27:
                exit(0);
        }
    }
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.02.2012, 22:49
Ответы с готовыми решениями:

Переписать программу, написанную на Borland C++
void search(vector&lt;string&gt;&amp; lines, string key) { string a; int i,j,x; ofstream outfile(&quot;result.txt&quot;); for( i=0; i&lt;lines.size();...

Переписать программу из Visual Basic в матлаб
Код Visual Basic Private Sub Command1_Click() Dim i%, k%, m Dim a(), y#(), max#, S# Dim R$ c = String(100, &quot;-&quot;) a =...

Помогите переписать программу с С на С++ (Система счисления)
#include &lt;stdio.h&gt; #include &lt;math.h&gt; void dvoich(int x1) { int i, b; long c = 0; for(i=0;x1 &gt;...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.02.2012, 22:49
Помогаю со студенческими работами здесь

Переписать программу для ряда Фурье с Visual studio 12 на Qt
Здравствуйте, пишу программу для ряда Фурье(с графиком и гармоникой).Имею рабочую версию программы на Visual studio 12, но мне надо...

Помогите переписать программу без использования индексации
Всем добрый вечер. помогите записать программу без: #include &lt;iostream&gt; #include &lt;string&gt; using std::cout; using std::cin; ...

Помогите найти ошибку или переписать программу!
Здравствуйте! Никак не могу справиться с одной задачей. Я и несколько одногруппников &quot;прокрутили в голове&quot; саму задачу и все...

Помогите найти ошибку в рекурсии, или переписать программу с использованием List
Программа переводит цифры и числа введённые с клавиатуры в слова using System; using System.Collections.Generic; using...

Помогите написать программу на Visual Basic!
Люди, срочно нужна ваша помощь!!! Никак не могу написать программу на Visual Basic, по причине того, что вообще ничего не понимаю в...


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

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

Новые блоги и статьи
Циклы for в Python
py-thonny 17.03.2025
Существует множество ситуаций, когда нам нужно выполнить одно и то же действие несколько раз. Цикл for в Python — настоящий рабочий конь для большинства программистов. Если вам нужно пройтись по всем. . .
Предсказание ветвлений - путь к высокопроизводи­тельному C++
NullReferenced 17.03.2025
В высокопроизводительном программировании на C++ каждый такт процессора на счету. Когда речь заходит о разработке систем с низкой задержкой — будь то высокочастотная торговля, обработка потоковых. . .
Паттерн CQRS в C#
UnmanagedCoder 17.03.2025
Создание сложных корпоративных приложений часто требует нестандартных подходов к архитектуре. Один из таких подходов — паттерн CQRS (Command Query Responsibility Segregation), предлагающий простую,. . .
Паттерн Цепочка ответственности в C#
UnmanagedCoder 17.03.2025
Цепочка ответственности — это поведенческий паттерн проектирования, который позволяет передавать запросы последовательно по цепочке потенциальных обработчиков, пока один из них не обработает запрос. . . .
Создаем микросервисы с NestJS, TCP и Typescript
run.dev 17.03.2025
NestJS — фреймворк, который значительно упрощает создание серверных приложений на Node. js. Его прелесть в том, что он комбинирует концепции ООП, функционального программирования и предлагает. . .
Гексагональная архитектура со Spring Boot
Javaican 17.03.2025
Если вы когда-нибудь сталкивались с ситуацией, когда внесение простых изменений в базу данных или пользовательский интерфейс заставляло вас переписывать весь код, то вы точно оцените элегантность. . .
Позиционировани­е Kafka Consumer и Seek-операции
Javaican 17.03.2025
Что же такое Consumer Seek в Kafka? По сути, это API-метод, который позволяет программно указать, с какой позиции (offset) Consumer должен начать или продолжить чтение данных из партиции. Без этого. . .
Python NumPy: Лучшие практики и примеры
py-thonny 17.03.2025
NumPy (Numerical Python) — одна из ключевых библиотек для научных вычислений в Python. Она превращает Python из просто удобного языка общего назначения в среду для проведения сложных математических. . .
Java Micronaut в Docker: контейнеризация с Maven и Jib
Javaican 16.03.2025
Когда речь заходит о микросервисной архитектуре на Java, фреймворк Micronaut выделяется среди конкурентов. Он создан с учётом особенностей облачных сред и контейнеров, что делает его идеальным. . .
Управление зависимостями в Java: Сравнение Spring, Guice и Dagger 2
Javaican 16.03.2025
Инъекция зависимостей (Dependency Injection, DI) — один из фундаментальных паттернов проектирования, который радикально меняет подход к созданию гибких и тестируемых Java-приложений. Суть этого. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер