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

Ошибка в выделении памяти - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Файловый ввод http://www.cyberforum.ru/cpp-beginners/thread1071984.html
Помогите пожалуйста решить задачу. Ввод из текстового файла "file1"(нужно самому создать этот файл) 1. -количество строк матрицы -количество столбцов матрицы -значения элементов матрицы(int) 2. определить номер столбцов матрицы,содержащие отрицательные элементы. 3. вывод результатов выполнения пункта 2 на экран 4. вывод результата выполнения пункта 2 в текстовый файл "file4" (его...
C++ Прочитать данные из файла Доброго времени суток! Помогите написать программку для чтения данных из файла, а то никак не получается. Есть файл, в первой строке которого я знаю, что написано. В матлабе всё отлично считывается, а повторить на С++ не получается. В первой строке подряд записаны следующие переменные: char long long char long long. Результат должен быть следующий: GIDR 2 344 test ta 10 2 Файл прилагаю. ... http://www.cyberforum.ru/cpp-beginners/thread1071973.html
C++ Классы, бинарное дерево, конструкторы. Исправить код
Здравствуйте! Не знаю, как исправить последнюю возникшую ошибку и заставить программу работать. А уже скоро сдавать и преподавателя доставать вопросами возможности нет... :( Помогите, пожалуйста, понять, что же тут не так, и заставить эту прогу работать, уже месяц противиться... 3 раз переделываю... // class3.cpp: определяет точку входа для консольного приложения. //
предложите свой алгоритм решения C++
Множество попарно различных плоскостей в трехмерном пространстве задано перечислением троек точек, через которые проходит каждая из плоскостей. Вы брать максимальное подмножество попарно непараллельных плоскостей. Во первых фишка в том, что нельзя использовать структуры, объекты и всякие плюшки из STL итп. Решать через массивы. Во вторых не совсем понимаю что тут написано ... если у нас...
C++ На каком участке кода происходит вызов функции http://www.cyberforum.ru/cpp-beginners/thread1071900.html
Привет всем! помогите розобратся, в каком месте(main) сдесь вызов функции( чтобы показать на блок схеме) и нужно ли на блок схеме писать первую часть до int main() #include "StdAfx.h" #include <iostream> #include <fstream> using namespace std;
C++ Исправьте ошибки в программах 2.Найти ту непрерывную последовательность положительных чисел, сумма элементов в которой максимальная (диапазон значений от -100 до 100): а) размер массива определяется в начале выполнения программы как случайное число в диапазоне 50-200 б) в тексте программы запрещается применять операцию индексации Программа к случаю а) #include <stdio.h> #include <conio.h> #include <stdlib.h>... подробнее

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

Ошибка в выделении памяти - C++

15.01.2014, 12:50. Просмотров 253. Ответов 2
Метки (Все метки)

проблема с выделением памяти. ошибку никак найти не могу, поможет кто исправить?

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
#include <iostream>
#include <stdlib.h>
 
using namespace std;
 
template <class T> class Queue
{
public:
    int size;
    int max_size;
    Queue();
    
    ~Queue();
        void push(T);
        T pop();
        Queue& operator=(const Queue);
    friend ostream& operator<<(ostream &stream, Queue a)
        {
    for (int i=0; i<a.size; i++)
        stream << a.A[i]<< " " ;
    stream <<endl;
    return stream;
        };
    friend istream &operator>> (istream &stream, Queue &a)
        {
    T temp;
    stream >>temp;
    a.push(temp);
    return stream;
        };
        int getSize(){return size;};
        int getMax_size(){return max_size;};
        Queue getA(){return A;};
private:
 
    T* A; 
};
 
template <class T>
Queue<T>::Queue()
{
    size = 0;
    max_size = 0;
    A = new T[size];
}
 
template <class T>
Queue<T>::~Queue()
{
    delete[] A;
}
 
template <class T>
void Queue<T>::push(T a)
{
        if (size < max_size-1)
        {
                A[size++] = a;   //добавление - в конце массива
                return;
        }
        max_size+=16;
        T* temp = new T[max_size];
        for (int i=0; i<size; i++)
                temp[i] = A[i];
        delete []A;
        A = temp;
        push(a);
}
 
template <class T> // удаление - в начале
T Queue<T>::pop()
{       T  element=A[0];
        for (int i=0; i<size; i++)
                A[i] = A[i+1];
        size--;
        return  element;
}
 
 
template <class T>
Queue<T>& Queue<T>::operator=(const Queue p)
{
    if(&p==this) return *this;
    
    size=p.getSize();
        cout<<p<<endl;
        max_size=p.getMax_size();
    A=new T[size];
 
    for(int i=0;i<size;i++)
    {
            //cout<<p.A[i]<<endl;
            A[i] = p.A[i];
            //cout<<A[i];
        }
 
        return *this;
}
 
 
 
 
 
int main()
{
        Queue<int> a;
        a.push(5);
        a.push(6);
        a.push(7);
        Queue<int> b;
        b.push(1);
        b.push(7);
        cout<<a<<endl;
        cout<<b<<endl;
        cout<<a.pop()<<endl;
        cout<<a<<endl;
        cout<<a.getSize()<<endl;
        cout<<a.getMax_size()<<endl;
        system("pause");
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru