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

Односвязный список - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Создание и считывание из файла http://www.cyberforum.ru/cpp-beginners/thread219578.html
В файле сохраняется информация о деятельности некоторых подразделов: наименование подраздела, количество сотрудников, прибыль, полученная за текущий квартал. сохранение я сделал #include<iostream.h> #include<conio.h> #include<fstream.h> void main() {clrscr(); struct podrozd {char naimenovanie;
C++ Программа, которая выдает краткую информацию по дисковым накопителям компьютера (на любом языке программирования) Программа, которая выдает краткую информацию по дисковым накопителям компьютера (общее число дисков, общий обьем каждого диска, используемый обьем, обьем свободного пространства). http://www.cyberforum.ru/cpp-beginners/thread219577.html
Напишите по-умному метод решения по этой программе. C++
Пожалуйста, напишите метод решения по данной задаче. Только чтобы четко, ясно и правильно ) /*Сама задача: Дано натуральное число выраженное в копейках, цене некоторого товара, например 317, 100 и т.д. Выразить цену в гривнах и копейках, например 3 грн. 17 коп. , 1 грн. 00 коп. Число копеек всегда записывается двумя цифрами. */ #include <stdio.h> #include <conio.h> #include <string.h>...
C++ Итераторы
При удалении элемента из списка (list) - ошибка list iterator not decrementable Что делать? for(Iter = npc.begin(); Iter != npc.end(); Iter++) delete (*Iter);
C++ Ввести строку и слово. Вывести те слова, которые не содержат букв, входящих в слово. http://www.cyberforum.ru/cpp-beginners/thread219558.html
Ребят помогите плииизз... только мне сказали через стандартную библиотеку Добавлено через 1 минуту Ах да и если не сложно, пояснения написать...
C++ Решить систему уравнений методом Гаусса Решить систему уравнений методом Гаусса ,вычислить Н=Е-Х*Хт 8,2х1-3,2х2+14,2х3+14,8х4=-8,4 5,6х1-12х2 +15х3 - 6,4х4=4,5 5,7х1+3,6х2-12,4х3-2,3х4=3,3 6,8х1+13,2х2-6,3х3-8,78х4=14,3 подробнее

Показать сообщение отдельно
Iworb
анимешник++
 Аватар для Iworb
93 / 60 / 2
Регистрация: 03.11.2009
Сообщений: 411
24.12.2010, 19:26     Односвязный список
Помогите пожалуйста, написал список, но компилятор зачастую зависает на одной строке:
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
template <class T>
struct el
{
    vector<T> x;
    vector<T> f;
    T norm;
    int iter;
    el *next;
};
 
template <class T>
class list
{
    protected:
        el<T> *head;
        int count;
        friend ostream& operator<<(ostream &o, list &l);
    public:
        list();
        list(list &l);
        ~list();
        void clear();
        void push(vector<T> x, vector<T> f, T norm);
        int size() {return count;};
        el<T>& operator[](int i);
        void pop();
};
 
    template <class T>
    list<T>::list()
    {
        head=NULL;
        count=0;
    }
 
    template <class T>
    list<T>::list(list<T> &l)
    {
        int i;
        head=NULL;
        for(i=0;i<l.count;i++)
        push(l[i].x,l[i].f,l[i].norm);
    }
 
    template <class T>
    list<T>::~list()
    {
        clear();
    }
    
    template <class T>
    void list<T>::push(vector<T> x, vector<T> f, T norm)
    {
        el<T> *nov=new el<T>;
        nov->x=x;
        nov->f=f;
        nov->norm=norm;
        nov->iter=count;
        nov->next=NULL;
        if(head==NULL)
        {
            head=nov;
            count++;
        }
        else
        {
            el<T> *temp=head;
            while(temp->next!=NULL) temp=temp->next; //вот тут компилятор начинает зависать
            temp->next=nov;
            count++;
        }
    }
    
    template <class T>
    void list<T>::pop()
    {
        if(head->next==NULL)
        {
            delete head;
            head=NULL;
            count=0;
        }
        else
        {
            el<T> *temp=head;
            while(temp->next->next!=NULL) temp=temp->next;
            delete temp->next;
            temp->next=NULL;
            count--;
        }
    }
    
    template <class T>
    void list<T>::clear()
    {
        while(head)
        {
            el<T> *temp=head;
            head=head->next;
            delete temp;
        }
        count=0;
        head=NULL;
    }
    
    template <class T>
    el<T>& list<T>::operator[](int i)
    {
        el<T> *temp=head;
        int n=0;
        while(temp->next&&n<i)
        {
            temp=temp->next;
            n++;
        }
        return *temp;
    }
    
template <class T>
ostream& operator<<(ostream &o, list<T> &l)
{
    el<T> *temp=l.head;
    while(temp)
    {
        char *p="|";
        o<<p<<setw(3)<<temp->iter
        <<p<<setw(10)<<temp->x[0]
        <<p<<setw(10)<<temp->x[1]
        <<p<<setw(10)<<temp->x[2]
        <<p<<setw(10)<<temp->f[0]
        <<p<<setw(10)<<temp->f[1]
        <<p<<setw(10)<<temp->f[2]
        <<p<<setw(8)<<temp->norm<<endl;
        temp=temp->next;
    }
    return o;
}
Кто знает в чем дело - помогите пожалуйста!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 14:44. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru