Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Файлы http://www.cyberforum.ru/cpp-beginners/thread70965.html
Ребят, помогите, пожалуйста. Написать среднее арифметическое и среднее квадратическое элементов файла и записать в другой файл. (с++) Не получается организовать работу с файлами.
Составить программу, моделирующую заполнение гибкого магнитного диска C++
задача такая Составить программу, моделирующую заполнение гибкого магнитного диска. Объем памяти на диске 360 Кбайт. Файлы имеют произвольную длину от 18 байт до 32 Кбайт. В процессе работы файлы...
C++ исправление элементов приближенной обратной матрицы
:(препод задал курсач,нужно написать программу для вычисления обратной матрицы на си++,используя метод исправления элементов приближенной обратной матрицы, это вычмат, у нас нет такого...
C++ Найдите ошибку! Помогите пожалуйста найти ошибку - не выводит ни суммы, ни произведения??? И как вводить с клавиатуры матрицу, чтобы она выглядела как матрица, а не всё в столбик??? Matr.h #ifndef __matr_h__... http://www.cyberforum.ru/cpp-beginners/thread70888.html
C++ Найти длину самого короткого и самого длинного слова http://www.cyberforum.ru/cpp-beginners/thread70879.html
помогите решить Дана символьная строка, содержащая текст, который заканчивается точ¬кой. Найти длину самого короткого и самого длинного слова.
C++ теория
народ мож кто знает где можно найти теорию или что-нибудь на подобии пособия,там где описывается про функции,про их применения и т.д. и т.п. Если кто знает скажите кде взять или сайт где можно...
Перекодировка с Паскаля на C++ C++
задача:задан в массиве вещественных чисел {aij} i и j от т1 до n, упорядочить по убыванию столбец,сумма элементов которого больше заданного числа B,код паскаля program masss; const m = 10;...
C++ Реализовать фунуцию Convert задача по С. Реализовать фунуцию Convert, которая осуществляет преобразование целого числа, переданного в параметре в виде строки, из одной системы счисления в другую. Основания исходной и целевой... http://www.cyberforum.ru/cpp-beginners/thread70862.html
C++ динамические структуры данных http://www.cyberforum.ru/cpp-beginners/thread70859.html
Задание: Разработать программу работы с бинарным деревом. Программа должна содержать следующие процедуры, вызываемые из меню: - построение пустого дерева; - добавление нового элемента;...
C++ Структуры Не могли бы помочь с программой. Информация о сотрудниках фирмы включает ФИО, табельный номер, количество отработанных часов за месяц, почасовой тариф. Рабочее время свы- ше 144 часов... http://www.cyberforum.ru/cpp-beginners/thread70854.html
lpofigistl
0 / 0 / 0
Регистрация: 29.11.2009
Сообщений: 2
0

Heap corruption detected

06.12.2009, 00:33. Просмотров 2266. Ответов 2
Метки (Все метки)

При попытке очистить память выдает "Heap corruption detected". Помогите пожалуйста(
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
163
164
165
166
167
168
169
170
171
172
173
174
175
176
// labanext.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"//включаем много интересных вещей
#include <stdlib.h>
#include <time.h>
#include <iostream>
#include <iomanip>
using namespace std;
 
void full(int **mtx,int n,int m)//заполение
{
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++)
            mtx[i][j]=rand()%99+1;
}
void out(int **mtx, int n, int m)//вывод матрицы
{
    cout<<"Matrix";
    for(int i=0;i<n;i++)
    {
        cout<<"\n";
        for(int j=0;j<m;j++)
            cout<<setw(3)<<mtx[i][j]<<" ";
    }
    cout<<"\n";
}
 
int har(int **mtx, int n,int m,bool what)//считаем характеристику и еденичные биты
{
    int kol=0;
    unsigned int mask=0x80000000,k;
    bool b;
    if(what)//true- считает для стобцов иначе для строк
    {
    k=mtx[0][m];
    for(int i=0;i<n;i++)
    k=k&mtx[i][m];
    }
    else
    {
    k=mtx[n][0];
    for(int i=0;i<m;i++)
    k=k&mtx[n][i];
    }
    //подсчет количества
    for(int i=0;i<sizeof(int)*8;i++)
    {
        b=(bool)(k&mask);
        if(b)
            kol++;
        mask>>=1;   
    }
    return kol;
}
void outhar(int **mtx, int n, int m)//выводит характеристики
{
    cout<<"CHRARACRERIZATION:"<<"\n";//считаем характеристики
    cout<<"OF columns:"<<"\n";//для колонок
    for(int j=0;j<m;j++)
    {
        unsigned int k=mtx[0][j];
        for(int i=0;i<n;i++)
            k=k&mtx[i][j];
        cout<<setw(3)<<k<<" ";
    }
    cout<<"\n";
    cout<<"OF rows:"<<"\n";
    for(int j=0;j<n;j++)//для столбцов
    {
        unsigned int k=mtx[j][0];
        for(int i=0;i<m;i++)
            k=k&mtx[j][i];
        cout<<setw(3)<<k<<" ";
    }
    cout<<"\n";
    cout<<"COUNT BIT:"<<"\n";//ввыводим число еденичных битов из каждой характеристики
    cout<<"OF columns:"<<"\n";
    for(int j=0;j<m;j++)
        cout<<setw(3)<<har(mtx,n,j,true)<<" ";//выводим еденичные биты числа
    cout<<"\n";
    cout<<"OF rows:"<<"\n";
    for(int j=0;j<n;j++)
        cout<<setw(3)<<har(mtx,j,m,false)<<" ";//выводим еденичные биты числа
    cout<<"\n";
}
 
int** magic(int **mtx,int *n,int *m)//используем указатель так как n и m должны измениться
{
    int *x=(int*)malloc(*m*sizeof(int));//массив для характеристик стобцов
    for(int j=0;j<*m;j++)//заполним его
            x[j]=har(mtx,*n,j,true);
    int l=0;//считаем сколько будет СТРОК
    for(int i=1;i<*n;i++)
        if(har(mtx,i,*m,false)!=har(mtx,i-1,*m,false))//сравниваем характеристики
            ++l;//увеличиваем показетель количества новых строк
    int k=0;//считаем сколько будет СТОЛБЦОВ
    for(int j=1;j<*m;j++)
        if(har(mtx,*n,j,true)!=har(mtx,*n,j-1,true))//сравниваем характеристики
            ++k;//увеличиваем показетель количества новых строк
    *n=*n+l;//новое количество строк
    //выделяем памяти под новые строки
    mtx=(int**)realloc(mtx,(*n)*sizeof(int));
    //теперь все перемещения для СТРОК
    for(int i=1;i<*n;i++)
        if(har(mtx,i,*m,false)!=har(mtx,i-1,*m,false))//сравниваем характеристики
        {
            memmove(mtx+i+1,mtx+i,(*n-i)*sizeof(int));
            mtx[i]=(int*)calloc(*m,sizeof(int));//вставляем нулевую строку заполненную нулями
            ++i;
        }
    //теперь все перемещения для СТОЛБЦОВ
    *m=*m+k;
    //начнем перемещения
    int c=1;
    for(int j=1;j<*m;j++)
    {
        if(x[c]!=x[c-1])
        {
            for(int i=0;i<*n;i++)
            {
                mtx[i]=(int*)realloc(mtx[i],*m*sizeof(int));//расширяем массив
                memmove(mtx[i]+j+1,mtx[i]+j,(*m-j)*sizeof(int));//перемещаем
                mtx[i][j]=0;
            }
            ++j;
        }
        ++c;
    }
    return mtx;
}
 
int main()
{
    cout<<"Lab 2, Option 8"<<"\n";
    srand((unsigned int)time(NULL));//включаем рандом
//получем размеры матрицы
    int m,n;
    n=2;m=2;//в случаем ввода знаков в размер матрицы за размер будет принято число 2
    cout<<"ENTER SIZE: "<<"\n";
n:cout<<"rows: ";
    cin>>n;//строки
    if(n<=0)
        goto n;
m:cout<<"columns: ";
    cin>>m;//столбцы
    if(m<=0)
        goto m;
//веделяем память из кучи
    int **mtx=(int**)malloc(n*sizeof(int));
    if(mtx == NULL)
    {
        cout << "Error: cannot allocate memory" <<"\n";
        goto n;
    }
    for(int i=0;i<n;i++)
    {
        mtx[i]=(int*)malloc(m*sizeof(int));
        if(mtx[i] == NULL)
    {
        cout << "Error: cannot allocate memory" <<"\n";
        goto n;
    }
    }
//делаем много полезного с памятью
    full(mtx,n,m);//заполняем случайными числами
    out(mtx,n,m);//вывод массива
    outhar(mtx,n,m);//выводим характеристики
    cout<<"RESULT:"<<"\n";
    mtx=magic(mtx,&n,&m);//преобразование, передаем адреса памяти
    out(mtx,n,m);
    for(int i=0;i<n;i++)
        free(mtx[i]);
    free(mtx);
    return 0;
}


Вернуться к обсуждению:
Heap corruption detected
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.12.2009, 00:33
Готовые ответы и решения:

HEAP CORRUPTION DETECTED
Собственно такую ошибку выдаёт: &quot;HEAP CORRUPTION DETECTED: after Normal block (#220) at 0x001970B8....

Heap Corruption detected (
что не правильно? запускаю и ошибка вылетает как на предидущей картинке template&lt;typename TT&gt;...

Heap corruption detected
Добрый день! Проблема вот в чём: когда выполнение кода доходит до 163 строки, появляется ошибка: &quot;...

Heap corruption detected
Heap corruption на строке 93 при первом же выполнении цикла. Из-за чего? #include &lt;locale.h&gt; //...

Heap Corruption Detected
Выдает ошибку HEAP CORRUPTION DETECTED, судя по всему где то ошиблась с распределением памяти...

2
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru