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

ошибка в указателе - 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. по окончанию всех оценок, прервать цикл управляемой меткой, и после этого программа должна вывести введёное кол-во каждой оценки. Моя проблема состоит в том,что не могу выбраться из цикла : При вводе метки просто выполняется условие по дефаулту. Помогите пожалуйcта, буду признателен. Вот сам проект. P.S... 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 00000001001 00000010001 00000100001 00001000001 00010000001 подробнее

Показать сообщение отдельно
Мортира
1 / 1 / 0
Регистрация: 18.04.2013
Сообщений: 39
22.05.2013, 20:47     ошибка в указателе
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;
 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:46. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru