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

Heap corruption detected - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Файлы http://www.cyberforum.ru/cpp-beginners/thread70965.html
Ребят, помогите, пожалуйста. Написать среднее арифметическое и среднее квадратическое элементов файла и записать в другой файл. (с++) Не получается организовать работу с файлами.
C++ Составить программу, моделирующую заполнение гибкого магнитного диска задача такая Составить программу, моделирующую заполнение гибкого магнитного диска. Объем памяти на диске 360 Кбайт. Файлы имеют произвольную длину от 18 байт до 32 Кбайт. В процессе работы файлы либо записываются на диск, либо удаляются с него. В начале работы файлы записываются подряд друг за другом. После удаления файла на диске образуется свободный участок памяти, и вновь записываемый файл... http://www.cyberforum.ru/cpp-beginners/thread70939.html
C++ исправление элементов приближенной обратной матрицы
:(препод задал курсач,нужно написать программу для вычисления обратной матрицы на си++,используя метод исправления элементов приближенной обратной матрицы, это вычмат, у нас нет такого предмета,открыла книжку,по которой он сказал готовиться(Демидович и Марон "Основы Вычислстельной математики") ничего не поняла,если сможете пожалуйста помогите....
C++ Найдите ошибку!
Помогите пожалуйста найти ошибку - не выводит ни суммы, ни произведения??? И как вводить с клавиатуры матрицу, чтобы она выглядела как матрица, а не всё в столбик??? Matr.h #ifndef __matr_h__ #define __matr_h__ const int N=2; const int M=2; typedef struct { double R; }matrix ;
C++ Найти длину самого короткого и самого длинного слова http://www.cyberforum.ru/cpp-beginners/thread70879.html
помогите решить Дана символьная строка, содержащая текст, который заканчивается точ¬кой. Найти длину самого короткого и самого длинного слова.
C++ теория народ мож кто знает где можно найти теорию или что-нибудь на подобии пособия,там где описывается про функции,про их применения и т.д. и т.п. Если кто знает скажите кде взять или сайт где можно найти,кровь из носу надо.вопрос жизни и смерти подробнее

Показать сообщение отдельно
lpofigistl
Сообщений: n/a

Heap corruption detected - C++

06.12.2009, 00:33. Просмотров 2078. Ответов 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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru