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

Обработка исключения - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как создать прямоугольную матрицу и чем она отличается от квадратной? http://www.cyberforum.ru/cpp-beginners/thread1190382.html
Как создать прямоугольную матрицу и чем она отличается от квадратной?
C++ Реализовать класс треугольник Задание №3. Реализовать классы "Отрезок", "угол", "треугольник", причем класс "угол" производный от класса "отрезок", а класс "треугольник" производный от "угол" и "отрезок". Метод display() этих классов должен создавать текстовую информацию об объекте(не рисовать). Метод draw() классов должен рисовать объект класса в графическом окне Windows Forms. В классе "треугольник" создать три... http://www.cyberforum.ru/cpp-beginners/thread1190371.html
Работа с файлами C++
Привет всем. Прошу Вашей помощи. Столкнулся с такой проблемой: никак не могу разбить программу реализации работы с файлами на несколько функций (нужно организовать ввод и вывод информации в отдельных функциях). А так же не знаю как сделать проверку на существования файла (при вводе и выводе данных проверка на существование файла с тем или иным именем и вывод соответствующего сообщения...
Рекурсивные функции: вывести цифры натурального числа n в обратном порядке C++
Помогите пожалуйста решить!!! Рекурсивно описать функцию rev_print (n), которая выводит цифры натурального числа n в обратном порядке. С++
C++ Class Array. Прокоментируйте программу http://www.cyberforum.ru/cpp-beginners/thread1190345.html
#include <iostream.h> #include <stdlib.h> class Array{ int n; int *p; static int count; public: void show(); Array operator+(Array &); void ERRMEM();
C++ Найти последнее слово в строчке Ввести массив из (максимум) 200 символов, вывести на экран последнее слово. подробнее

Показать сообщение отдельно
pedro78
0 / 0 / 0
Регистрация: 12.11.2012
Сообщений: 31

Обработка исключения - C++

27.05.2014, 20:41. Просмотров 236. Ответов 0
Метки (Все метки)

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
// ConsoleApplication1.cpp: определяет точку входа для консольного приложения.
//
 
 
#include "stdafx.h"
 
 
#include <iostream>
#include <stdio.h>//На эти три библиотеки можно не обращать внимания, я всегда
#include <math.h>//их пишу на всякий случай,
#include <stdlib.h>//вдруг пригодятся.
 
 
struct ZAYAVKA
{
char city[40];
char flight[10];
char fio[40];
char leave_date[20];
};
 
 
struct NODE
{
ZAYAVKA data;
NODE *right,*left;
};
 
void pr(NODE *root)
{
  if(root!=NULL){
  if(root->left!=NULL)
    pr(root->left);
  printf("%15s%7s%20s%12s\n", root->data.city,root->data.flight,root->data.fio,root->data.leave_date);
  if(root->right!=NULL)
    pr(root->right);
  }
}
 
NODE *add(NODE *root,NODE *p)
{
if(root==NULL) //esli pustoi to dobavit pervii el v root
  root=p;
else
{
  if(strcmp(p->data.leave_date,root->data.leave_date)) 
  root->left=add(root->left,p);   //dobavit v levyu vetku
  if(strcmp(p->data.leave_date,root->data.leave_date)>0)
  root->right=add(root->right,p); //v pravyu
  }
return root;
}
 
NODE* vvod_zay()
{
NODE *p;
p=(NODE *) malloc(sizeof(NODE));
getchar();
printf("Vvedite Punkt naznachenia: ");
gets_s(p->data.city);
printf("Vvedite Nomer reisa: ");
gets_s(p->data.flight);
printf("Vvedite FIO: ");
gets_s(p->data.fio);
printf("Vvedite Daty otpravlenia(v formate:yyyy.mm.dd): ");
gets_s(p->data.leave_date);
printf("Vvod complete");
p->left=p->right=NULL;
return p;
}
 
 
 
NODE* poisk_zayav(NODE *root,ZAYAVKA z, NODE **pred)
{
NODE *p;
 
p=root;
while(p!=NULL)
{
  if((strcmp(p->data.city,z.city)==0) && (strcmp(p->data.flight,z.flight)==0) && (strcmp(p->data.fio,z.fio)==0) && (strcmp(p->data.leave_date,z.leave_date)==0))
  {
  return p;
  }
  *pred=p;
  if(strcmp(z.leave_date,p->data.leave_date))
      root->left;
  else
  p=p->right;
}
return p;
}
 
void udal_NODE(NODE **p, NODE *pred, NODE **root)
{
NODE *k,*l;
 
if((*p)->left!=NULL)
  {
  k=(*p)->left;
  while(k->right!=NULL)
    k=k->right;
  if(pred!=NULL)
    if(pred->left==(*p))
    pred->left=k;
    else
    pred->right=k;
  else
    *root=k;
  k->right=(*p)->right;
  if((*p)->left!=k)
  {
    l=(*p)->left;
    while(l->right!=k)
    l=l->right;
    l->right=k->left;
    k->left=(*p)->left;
  }
  free(*p);
  *p=k;
  }
else
  if((*p)->right!=NULL)
  {
  k=(*p)->right;
  while(k->left!=NULL)
    k=k->left;
  if(pred!=NULL)
    if(pred->left==(*p))
    pred->left=k;
    else
    pred->right=k;
  else
    *root=k;
  k->left=(*p)->left;
  if((*p)->right!=k)
  {
    l=(*p)->right;
    while(l->left!=k)
    l=l->left;
    l->left=k->right;
    k->right=(*p)->right;
  }
  free(*p);
  *p=k;
  }
  else
  {
  if(pred!=NULL)
    if(pred->left==(*p))
    pred->left=NULL;
    else
    pred->right=NULL;
  else
    *root=NULL;
  free(*p);
  }
}
 
void udal(NODE **root)
{
NODE *a; //ukazatel na uzel
NODE *pred=NULL;
struct ZAYAVKA z;
 
getchar();
printf("Vvedite vse polya zayavki, kotoryu hotite udalit: \n");
printf("Vvedite punkt naznacheniya: ");
gets_s(z.city);
printf("Vvedite nomer reisa: ");
gets_s(z.flight);
printf("Vvedite fio: ");
gets_s(z.fio);
printf("Vvedite daty otpravleniya v formate yyyy.mm.dd: ");
gets_s(z.leave_date);
a=poisk_zayav(*root,z,&pred);
if(a==NULL)
  printf("Sovpadenii ne naideno=(");
else
{
  udal_NODE(&a,pred,root);
  printf("Udalenie uspeshno ");
}
}
 
NODE* poisk_zayav(NODE *root, char *numb, char *date, NODE **pred)
{
NODE *p;
 
p=root;
while(p!=NULL)
{
  if((strcmp(p->data.flight,numb)==0) && (strcmp(p->data.leave_date,date)==0))
  {
  return p;
  }
  *pred=p;
  if(strcmp(date,p->data.leave_date))
      root->left;
  else
  p=p->right;
}
return p;
}
 
void p2(NODE **root)
{
char numb[10];
char date[20];
NODE *a;
NODE *pred;
    try{
printf("Vvedite nomer reisa: ");
scanf_s("%s", numb);
printf("Vvedite daty vileta v formate gggg.mm.dd: ");
scanf_s("%s", date);
 
    }
        catch(...)
        {
        printf("nononononoonononon");
    }
while(1)
 
{
  a=poisk_zayav(*root,numb,date,&pred);
  if (a==NULL) break;
  printf("%15s%7s%20s%12s\n", a->data.city, a->data.flight, a->data.fio, a->data.leave_date);
  udal_NODE(&a,pred,root);
}
}
 
 
void main()
{
int a;
struct NODE *root=NULL;
system("cls");
 
while(1)
    {
    system("cls");
    printf("1.Otobrazit zayavky\n");
    printf("2.Otobrazit zayavky po nomery reisa i date vileta c ydaleniem\n");
    printf("3.Dobavit zayavky\n");
    printf("4.Ydalit zayavky\n");
    printf("5.Exit\n");
    printf("Vvedite nomer pynkta: ");
    scanf_s("%d",&a);
 
    switch(a)
      {
case 1:system("cls"); pr(root); break;
case 2:system("cls"); p2(&root); break;
 
case 3:system("cls"); root=add(root,vvod_zay()); break;   //vvod zay; vozvrashaetsya zay+peredaetcua v derevo;
    
 
case 4:system("cls"); udal(&root); break;
case 5:exit(0);
      }
    
    system("pause");
  }
}



при выборе пункта 2, после ввода номера рейса(полета) вылетает сообщение: "Необработанное исключение по адресу 0xFEFEFEFE в ConsoleApplication1.exe: 0xC0000005: нарушение прав доступа при исполнении по адресу 0xFEFEFEFE." Вроде бы в функции в 206 строке я пытался поймать, но ничего не выходит
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru