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

Динамический список (нарушение прав доступа) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти элементы, которые встречаются во всех трех массивах http://www.cyberforum.ru/cpp-beginners/thread727716.html
Заданы три одномерных массива содержащие по n элементов. Написать программу, которая находит те элементы, которые встречаются одновременно во всех трех массивах.
C++ Освобождает ли Есть функция: void CreateQ() { Document* doc; //Базовый класс cout<<"Создание объекта Queitus (Квитанция):"<<endl<<endl;; string t="Тейкер", s="Сендер"; int sm = 100; string dat="21.12.2012"; int id = 1; http://www.cyberforum.ru/cpp-beginners/thread727712.html
Посчитать количество слов во введенной строке символов, начинающихся с «Т» или «т» C++
Собственно вообще не осознаю как делать, может кто помочь? Есть наработка.. но почему то не работает, не хочет считать. Была мысль и чет походу дела потерял, помогите пожалуйста. #include <iostream> #include <string> using namespace std; int main() {
C++ Сортировка элементов пободчной диагонали матрицы методом выбора
Подкиньте мысль...... Необходимо упорядочить эл-ты побочной диагонали массива по возрастанию методом выбора... Я даже не очень понимаю, как мне эти эл-ты отделить от всей матрицы, а как сортировку правильно сделать совсем завис..... Что такое сортировка выбором знаю, а применить не могу... Добавлено через 3 часа 29 минут подскажите!
C++ Поля дружественного класса http://www.cyberforum.ru/cpp-beginners/thread727700.html
есть примерно такой код class ClientAuthorization { public: int count; //считается в конструкторе, не буду писать весь код, а то много получится friend class Role; void Function(); }; void ClientAuthorization::Function()
C++ работа с rand вот фрагмент из программы, он выводит массив: #include <stdio.h> #include <conio.h> #include <iostream.h> #include <stdlib.h> #define n 10 #define k 5 #define krasota printf ("\n___________________________________________________________") main() { подробнее

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

Динамический список (нарушение прав доступа) - C++

11.12.2012, 18:18. Просмотров 390. Ответов 5
Метки (Все метки)

Всем здравствуйте! При написании шаблона класса для хранения динамического списка элементов наткнулся на ошибку "Первый этап обработки исключения по адресу 0x00C05101 в class_list.exe: 0xC0000005: нарушение прав доступа при чтении по адресу 0x00000005."
Текущий шаг дебага указывает на строку while (cur -> next != NULL). В чём может быть проблема? Заранее благодарен.

P.S. Если запретить конструктор копирования и оператор присваивания (прописать в private), вылетает ошибка C1001.

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
#include "iostream"
using namespace std;
template <typename T>
 
 
 
class List
{
private:
    struct Element
    {
        T data;
        Element * next;
    };
    Element * head;
    Element * cur;
    Element * prev;
public:
   
List(void)
{
    head = NULL;
}
 
 
~List(void)
{
    Element * p = head;
    while (p != 0)
    {
        Element * next = p->next;
        delete p;
        p = next;
    }
}
 
 
void push_front(T el)
{
    Element * temp = new Element;
    temp->data = el;
    if (head == NULL)
    {
        head = temp;
    }
    Element * newHead = temp;
    newHead->next = head;
}
 
 
T del_front(void)
{
    T x;
    if (head == NULL)
    {
        std::cout << "List is empty!";
        getchar();
        exit(1);
    }
    x = head -> data;
    Element * newHead = head->next;
    delete head;
    head = newHead;
    cout << x;
    return x;
}
 
 
void push_back(T el)
{
    Element * temp = new Element;
    temp -> data = el;
    Element * cur;
    if (head == NULL)
    {
        head = temp;
    }
    else
    {
        cur = head;
        while (cur -> next != NULL)
        {
            cur = cur -> next;
        }
        cur -> next = temp;
    }
}
 
T del_back(void)
{
    T x;
    Element * cur = head;
    while (cur -> next != NULL)
    {
        cur = cur -> next;
    }
    x = cur -> data;
    delete cur;
    cout << x;
    return x;
}
 
};
 
int main()
{
    List<int> list;
    getchar();
    for (int i = 0; i < 5; i++)
    {
        list.push_front (i);
    }
    getchar();
    list.push_front(15);
    getchar();
    list.del_front();
    getchar();
    list.push_back(10);
    getchar();
    list.del_back();
    getchar();
    return 0;
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru