Форум программистов, компьютерный форум, киберфорум
Наши страницы

Ошибка в указателе при работе со списком - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Инвертирование текста http://www.cyberforum.ru/cpp-beginners/thread874967.html
Есть текст, например: Beautiful Explicit Simple Complex Я хочу его инвентировать по вертикале сначало, т. е. должно получится: Complex Simple Explicit Beautiful
C++ Определить введенное количество каждого вида отметок Собственно задача программы : Нужно ввести N-ое количество буквенных оценок A,B,C,D,F. по окончанию всех оценок, прервать цикл управляемой меткой, и после этого программа должна вывести введёное... http://www.cyberforum.ru/cpp-beginners/thread874962.html
Модель Автостоянки на С++ C++
помогите написать программу. при помощи графики в с++ нарисовать модель автостоянки. распределение по местам рандомно , поиск свободных мест и т.д.
C++ Опишите функцию анализа номера телефон: обработайте ошибку задания номера в неверном формате
помогите с программкой: Опишите функцию анализа номера телефона, обработайте ошибку задания номера в неверном формате (допустимый формат - +4(093)444-00-22)
C++ Bз входной последовательности вывести гласные, согласные, цифры http://www.cyberforum.ru/cpp-beginners/thread874916.html
С++. В входной последовательности имеется текст . Задача: из входной последовательности вывести гласные,согласные,цифры.
C++ Заполнить матрицу 11 на 11 единицами в форме треугольника Здравствуйте помогитье решить задачку. Заполнить матрицу 11 на 11 единицами в форме треугольника. Сижу разбираюсь но понять ничего пока что не могу. 00000000001 00000000011 00000000101... подробнее

Показать сообщение отдельно
Мортира
1 / 1 / 0
Регистрация: 18.04.2013
Сообщений: 47

Ошибка в указателе при работе со списком - C++

22.05.2013, 20:47. Просмотров 210. Ответов 1
Метки (Все метки)

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
#include "stdafx.h"
#include <iostream>
#include <conio.h>
#include <cstdio>
#include <cstring>
#include"string.h"
using namespace std;
 
struct Node
{
    friend class StackString;
    char* data;
    Node *next;
};
 
class StackString
{
 
private:
    Node* front;
    Node* back;
public:
    friend istream& operator >>(istream&, StackString&);
    friend ostream& operator <<(ostream&, StackString&);
    StackString() {back=front=NULL;};
    StackString(char **arr, int n);
    StackString(const StackString& obj);
    ~StackString()
    {
        while(back!=front)
        {
            Node* p=front;
            front=front->next;
            delete p;
        }
        back=front=NULL;
    }
    void Add(char*& str);
    void Del();
    bool Empty() {return front == NULL ? true: false;};
    char* operator!();
};
 
void StackString::Add(char*& str)
{
    Node* p= new Node;
    p->data=str;
    if(Empty())
    {
        front=back=p;
        p->next=NULL;
 
    }
    else
    {
        back->next=p;
        p->next=NULL;
        back=p;
    }
 
}
 
void StackString::Del()
{
    int n; cin>>n;
    Node *p=front;
    for(int i=0; i<n-1; i++)
        {
            p=p->next;
        }
        Node* S=p;
        p=p->next; Node* tmp=p;
        p=p->next;
        S->next=p;
        delete p; delete tmp;
}
 
 
StackString::StackString(char **arr, int n)
{
    front=back=NULL;
    for(int i=0; i<=n; i++)
        Add(arr[i]);
 
}
 
StackString::StackString(const StackString& obj)
{
    back=front=NULL;
    Node* ptr=obj.front;
    while(ptr)
    {
        Add(ptr->data);
        ptr=ptr->next;
    }
}
char* StackString::operator!()
{
 Node* ptr=front;
 Node* p=front;
    while(ptr)
    {
 
        if(strlen(p->data)<strlen(ptr->data))
            p=ptr;
        ptr=ptr->next;
    }
    return p->data;
}
ostream& operator <<(ostream& os, StackString& q)
{
    cout<<"< ";
    Node* ptr=q.front->next;
    while(ptr)
    {
        os<<ptr->data<<", ";
        ptr=ptr->next;
    }
    cout<<" >"<<endl;
    return os;
}
 
istream& operator >>(istream& is, StackString& q)
{
    q.~StackString();
    int n, size, arr, massiv(int i[100]); cout<<"Введите количество элементов"<<endl; 
    cin>>size;
    int* MyArray;
    MyArray = new int [size]; 
    
    for(int i=0; i<size; i++)
    int i = new char [32];
    for(int i=0; i<=n; i++){
        cin.getline(arr[i], 32);
    }
    return is;
}
 
int main()
{
    setlocale(LC_ALL,"russian");
 
    int n; cin>>n;
    char* arr[10];
    for(int i=0; i<10; i++)
        arr[i]=new char [32];
    for(int i=0; i<=n; i++)
        cin.getline(arr[i], 32);
    StackString A(arr, n);
    arr[3]=new char[100];
    cout<<"Наибольший:\t"<<!A<<endl;
    cout<<A;
    cin>>A;
    A.Del();
    cout<<A;
    StackString B(A);
    for(int i=0; i<=n; i++)
        delete arr[i];
    getch();
    return 0;
 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru