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

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

29.02.2012, 22:49. Показов 562. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Чеклист для Kubernetes в продакшене: Лучшие практики для SRE
Mr. Docker 19.03.2025
Когда сталкиваешься с запуском Kubernetes в продакшене, невольно задаешься вопросом: почему то, что так гладко работало в тестовой среде, вдруг начинает вызывать головную боль на боевых системах?. . .
Разработка продвинутого ИИ в Unity с использованием Behavior Graph
GameUnited 19.03.2025
В разработке игр искусственный интеллект персонажей часто становится тем элементом, который превращает хорошую игру в выдающуюся. До недавнего времени разработчикам под Unity приходилось либо писать. . .
Словари в Python: методы работы, оптимизация, сериализация
py-thonny 19.03.2025
Каждый хотя бы раз сталкивался с необходимостью хранить связанные данные, где важна не только сама информация, но и их взаимосвязь. В дебрях Python словари — это тот универсальный инструмент, который. . .
Реализация паттерна CQRS с Event Sourcing в PHP
Jason-Webb 19.03.2025
CQRS (Command Query Responsibility Segregation) — это архитектурный паттерн, который разделяет операции чтения и записи данных в приложении. Если вы столкнулись с ситуацией, когда ваше PHP-приложение. . .
std::span в C++: Подпредставлени­я и срезы
NullReferenced 18.03.2025
Если вы когда-нибудь работали с большими объемами данных в C++, то наверняка сталкивались с необходимостью манипулировать отдельными частями массивов или контейнеров. Традиционные подходы часто. . .
std::span в C++: Доступ к элементам и итерирование
NullReferenced 18.03.2025
В C++ каждый разработчик сталкивается с проблемой эффективного управления последовательностями данных. Представьте: вы работаете с массивом, передаете его в функцию, а затем в другую, и каждый раз. . .
Утечки памяти в C#
UnmanagedCoder 18.03.2025
Когда мы говорим о разработке приложений на C#, то часто успокаиваем себя мыслью, что сборщик мусора решит все наши проблемы с памятью. "Память управляется автоматически" — эта мантра прочно засела в. . .
std::span в C++: Введение в невладеющее представление
NullReferenced 18.03.2025
С появлением стандарта C++20 у нас появился новый инструмент — std::span, который представляет собой невладеющее представление для работы с последовательностями данных. std::span — это легковесный. . .
Введение в Dapr для разработчиков .NET
UnmanagedCoder 18.03.2025
Разработка распределенных систем никогда не была настолько востребованной и одновременно такой сложной. Если вы . NET разработчик, то наверняка сталкивались с необходимостью жонглировать обнаружением. . .
Собеседование по Spring Boot: продвинутые вопросы и ответы
Javaican 18.03.2025
Собеседования на позиции старших разработчиков и архитекторов требуют глубокого понимания внутренних механизмов Spring Boot, нюансов конфигурирования, подходов к оптимизации и построению сложных. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер