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

Почему выдает ошибку при вводе? - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Написать программу которая преобразует введенное с клавиатуры трехразрядное шестнадцатеричное число http://www.cyberforum.ru/cpp-beginners/thread1191848.html
Помогите пожалуйста написать программу!Язык С++! Задание:"Написать программу которая преобразует введенное с клавиатуры трехразрядное шестнадцатеричное число в десятичное" - с проверкой на шестнадцатеричность(чтобы можно было вводить только трехразрядные шестнадцатеричные числа) Заранее огромное спасибо!!!)))
C++ Определить, является ли заданная матрица ортогональной Квадратная матрица A называется ортогональной, если AT=A-1. Определить, является ли заданная матрица A(n,n) ортогональной. Использовать динамические матрицы http://www.cyberforum.ru/cpp-beginners/thread1191838.html
Составить программу поиска элементов массива, которые являются наименьшим из отрицательных чисел C++
Задан числовой массив А. Составить программу поиска элементов массива, которые является наименьшим из отрицательных чисел, расположенных над главной диагональю и наименьшим из положительных чисел в той же области Помогите справить задачу, нужно справить чтобы числа в водились через консоль, а у меня написано когда включаю консоль. Буду очень благодарен если поможете.. #include <time.h>...
C++ Двумерный массив: подсчитать произведение одной и второй диагонали
Данный двумерный массив чисел. Подсчитать произведение одной и второй диагонали массива чисел.
C++ Поиск элементов массива, исправить задачу http://www.cyberforum.ru/cpp-beginners/thread1191809.html
Задан числовой массив А. Составить программу поиска элементов массива, которые является наименьшим из отрицательных чисел, расположенных над главной диагональю и наименьшим из положительных чисел в той же области. Буду очень благодарен если поможете с задачей, так как задача готово, в Консоль сразу все выдает, но нужно чтобы считало все через консоль что я пишу. #include <time.h>...
C++ Поправьте Код #include <stdio.h> #include <conio.h> #include <time.h> #include <stdlib.h> #include <iostream.h> #include <math.h> int main() { int k={1,2,3,4}; подробнее

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

Почему выдает ошибку при вводе? - C++

28.05.2014, 22:37. Просмотров 440. Ответов 8
Метки (Все метки)

Вот моя программа. Она перестала работать после того как я добавил функцию (invers). Эта функция должна инвертировать второй список.
После включения программы я должен ввести количество элементов первого списка. И сразу потом каждый элемент.
Но как только я ввожу первый элемент - программа выдает ошибку.

вот моя программа:
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
// ///////////////////////////////////////// 6.5 ///////////////////////////////////////////////////////////
//
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream>
#include <conio.h>
using namespace std;
 
struct List
{
    int inf;
    List *Link;
};
 
class ListClass
{
    List *Head1, *Head2;
 
public:
 
    void InitP();  //инициализация списка
    void CreateP1();  //создание списка 1
    void CreateP2(); //создание списка 2 
    void PrintP1();  //вывод списка 1
    void PrintP2();  //вывод списка 2
    void invers(); //ниверсия  второго списка
 
    void DelElem();  //удаление второго элемента списка
    List *find1(int b);  //нахождение элемента в списке для его замены
    void doit(int n);  //замена элемента списка
    void find2();  //постановка последнего элемента списка перед первым элементом
 
};
 
//инициализация списка
inline void ListClass::InitP()
{
    Head1, Head2 = NULL;
}
 
//создание списка 1
void ListClass::CreateP1()
{
    List *p = new List;
    cin >> p->inf;
    p->Link = NULL;
 
    if (Head1 == NULL)
        Head1 = p;
    else
    {
        List *Temp = Head1;
        while (Temp->Link != NULL)
            Temp = Temp->Link;
        Temp->Link = p;
    }
}
 
//создание списка 2
void ListClass::CreateP2()
{
    List *p2 = new List;
    cin >> p2->inf;
    p2->Link = NULL;
 
    if (Head2 == NULL)
        Head2 = p2;
    else
    {
        List *Temp = Head2;
        while (Temp->Link != NULL)
            Temp = Temp->Link;
        Temp->Link = p2;
    }
}
 
//вывод списка
void ListClass::PrintP1()
{
    List *q = Head1;
    if (Head1 == NULL)
    {
        cout << "Список пуст = 0" << endl;
        return;
    }
    cout << endl;
 
    while (q != NULL)
    {
        cout << q->inf << endl;
        q = q->Link;
    }
}
 
void ListClass::PrintP2()
{
    List *q = Head2;
    if (Head2 == NULL)
    {
        cout << "Список пуст = 0" << endl;
        return;
    }
    cout << endl;
 
    while (q != NULL)
    {
        cout << q->inf << endl;
        q = q->Link;
    }
}
 
//удаление второго элемента списка
void ListClass::DelElem()
{
    List *d;
    d = Head1->Link;
    Head1->Link = d->Link;
    delete d;
}
 
//нахождение элемента в списке для его замены
List* ListClass::find1(int b)
{
    List *first = Head1;
    while (first != NULL)
    {
        if (first->inf == b)
            return first;
 
        else first = first->Link;
    }
    return NULL;
}
 
//замена элемента списка
void ListClass::doit(int n)
{
    int c, b;
    cout << "Введите значение элемента: ";
    cin >> b;
    cout << "Введите новое значение элемента: ";
    cin >> c;
    List *p = Head1;
    {
        if (b == p->inf)
        {
            p->inf = c;
        }
        p = p->Link;
    }
}
 
//постановка последнего элемента списка перед первым элементом
void ListClass::find2()
{
    List *last = Head1, *temp = Head1;
 
    while (last->Link != NULL)// Доходим до конца списка
    {
        temp = last;
        last = last->Link;
    }
    List *p = new List;
    p->inf = Head1->inf;
    p->Link = Head1->Link;
    Head1->inf = last->inf;
    Head1->Link = p;
    temp->Link = NULL;
    last = NULL;
}
 
void ListClass::invers()
{
    List *tmp = Head2;
    while (tmp)
    {
        List *f = new List;
 
        f->inf = tmp->inf;
        cout << tmp->inf;
        if (Head2 == NULL)
        {
            f->Link = NULL;
        }
        else f->Link = Head2;
        Head2 = f;
        tmp = tmp->Link;
    }
}
 
int main()
{
    setlocale(LC_ALL, "RUS");
    ListClass ob;
    List *Head1, *Head2;
 
    //////////////////////////////////////////////////////// УДАЛЯЕМ ВТОРОЙ ЭЛЕМЕНТ ////////////////////////////////////////////////////////
    ob.InitP();
 
    int i, n;
    cout << "Введите кол-во: ";
    cin >> n;
    cout << "Введите элементы первого списка: " << endl;
    for (i = 1; i <= n; i++)
        ob.CreateP1();
    cout << endl << endl;
    cout << "Ваш список: " << endl;
    ob.PrintP1();
    cout << endl;
    cout << "Удаляем второй элемент из вашего списка. " << endl << endl;
    ob.DelElem();
    cout << "Ваш список без второго элемента: " << endl;
    ob.PrintP1();
 
    ////////////////////////////////////////////////////////// МЕНЯЕМ ЭЛЕМЕНТ ////////////////////////////////////////////////////////////////
 
    cout << "Поиск элемента." << endl << endl;
    int b, c;
 
    cout << "Введите значение элемента: ";
    cin >> b;
    cout << "Введите новое значение элемента: ";
    cin >> c;
 
    if (ob.find1(b))
        ob.find1(b)->inf = c;
    ob.PrintP1();
 
    ///////////////////////////////////////////////////////// ПОСЛЕДНИЙ ЭЛЕМЕНТ СТАВИМ ПЕРЕД ПЕРВЫМ ////////////////////////////////////////////
 
    ob.find2();
    cout << "Переносим последний элемент списка на начало: " << endl;
    ob.PrintP1();
 
    //////////////////////////////////////////////////////////// СОЗДАЕМ ВТОРОЙ СПИСОК /////////////////////////////////////////////////////////
 
    cout << "Введите кол-во: ";
    cin >> n;
    cout << "Введите элементы второго списка: " << endl;
    for (i = 1; i <= n; i++)
        ob.CreateP2();
    cout << endl << endl;
    cout << "Ваш список: " << endl;
    ob.PrintP2();
    cout << endl;
 
    /////////////////// ИНВЕРТИРУЕМ ВТОРОЙ СПИСОК /////////////////////////////
 
    ob.invers();
 
 
    _getch();
 
    system("pause");
    return 0;
}
Миниатюры
Почему выдает ошибку при вводе?  
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru