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

Чтение памяти невозможно - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Найти сумму цифр числа http://www.cyberforum.ru/cpp-beginners/thread1169638.html
Вообщем все обстоит примерно так : #include <iostream> #include <math.h> using namespace std; int number_of_digits(int n) { int count = 0; while(n)
C++ Из динамического массива X(N) все простые числа записать в массив Y(k), а остальные - в массив Z(m) Из целочисленного динамического массива X(N) все простые числа записать в массив Y(k), а все элементы, не являющиеся простыми числами, - в массив Z(m). Помогите исправить ошибку. #include "stdafx.h" #include <iostream> #include <stdlib.h> #include <time.h> using namespace std; void form(int* X,int N) http://www.cyberforum.ru/cpp-beginners/thread1169623.html
Remove_if - при передаче функции класса выдает ошибки C++
#include <QCoreApplication> #include <vector> using namespace std; template <class T> class c_equ { protected: T equ; public: c_equ(int new_val)
C++ Построчно найти любые четыре числа (ячейки) и записать в них нули
Дан массив - 3 строки, 9 столбцов. Нужно ПОСТРОЧНО найти любые четыре числа (ячейки) и записать в них нули:scratch:
C++ Сортировка массива структур http://www.cyberforum.ru/cpp-beginners/thread1169592.html
Помогите с сортировкой(имён). Долго мучился но что то не получаться. Функция void BubbleSort Функция не работает!Помогите с кодом. #include <iostream> #include <fstream> #include <string>
C++ Не предлагается ввод второго массива Есть код, 2 задания, вводятся числа, подсчитывается минимальное число и максимальное, пото мсновва вводятся числа, и подсчитывается количество отривательных чисел, проблема в том что доходя до второго задания ввод чисел не предлагается и я немогу понять почему #include <iostream> #include <string> #include <Windows.h> using namespace std; void write_the_text(string text){ for (int i... подробнее

Показать сообщение отдельно
tim289
4 / 4 / 2
Регистрация: 15.02.2014
Сообщений: 25
07.05.2014, 22:41     Чтение памяти невозможно
Ребята помогите, не понимаю где ошибка вот весь код
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
#include <iostream>
#include <vector>
#include <map>
#include <list>
#include <fstream>
#include <string>
using namespace std;
 
class Node
{
public:
    int num;
    char cha;
    Node *left,*right;
 
    Node(){};
 
    Node (Node *l, Node *r)
    {
        left=l;
        right=r;
        num= l->num+r->num;    }
 
};
struct sortt
{ bool operator()(Node* l, Node* r) const {return l->num < r->num;}};
 
vector<bool> code;
map<char,vector<bool> > table;
 
void contrtable(Node *root)
{
    if (root->left!=NULL)
                      { code.push_back(0);
                      contrtable(root->left);}
 
    if (root->right!=NULL)
                       { code.push_back(1);
                       contrtable(root->right);}
 
    if (root->cha) table[root->cha]=code;
 
    code.pop_back();
}
 
int main()
{
        setlocale(LC_ALL,"Russian");                           //подключаем кириллицу в консоль
        string str,str1,str2,str4;                                    //создаем строки, чтоб дальше их использовать как имена файлов
        cout<<"Введите имя файла(без расширения):"<<endl;
        cin >> str1;
        cout<<"Введите расширение файла(пример: .txt):"<<endl;
        cin >> str2;
        str=str1+str2;                                           //соединяем имя файла и его расширение
 
        ifstream file(str.c_str(), ios::binary);                //открываем файл в режиме чтения в двоичной системе счисления, прикрепляя его к имени "file"
        if (!file)                                                   //проверяем открылся ли файл
        cout << "Ошибка. Такого файла не существует!" << endl;
        else
        {
        map<char,int> lst;
        char ch;
        int sizef=0;
                while (file.read((char*)&ch, 1))                    //считываем открытый файл побайтно в переменную "ch"
        {
            if (file.eof()) break;                          //проверяем не кончился ли файл
            lst[ch]++;
            sizef++;
                                                //байт("ch")-номер элемента массива, добавляем +1 к элементу
        }
 
 
 
        map<char,int>::iterator ii;
        list<Node*> tree;
        for (ii=lst.begin();ii!=lst.end();ii++)
            {
                 Node *p = new Node;
                 p->num = ii->first;
                 p->cha = ii->second;
                 tree.push_back(p);
            }
        while(tree.size()!=1)
        {
            tree.sort(sortt());
            Node *sl=tree.front();
            tree.pop_front();
            Node *sr=tree.front();
            tree.pop_front();
 
            Node *parent= new Node(sl,sr);
            tree.push_back(parent);
        }
            Node *root=tree.front();
 
            contrtable(root);
 
 
            str4=str1+".Haf";                                    //создаем имя второго файла
            double c,e=0;
            ofstream file2(str4.c_str(), ios::binary);           //открываем сам файл в режиме записи
            file2<<str1<<str2<<endl;                            //записываем в файл его имя
            file2<<sizef<<endl<<endl;
 
            map<char,vector<bool> >::iterator i;
                                          //записываем в файл размер первого файла
 
        for (i=table.begin();i!=table.end();i++)
            {
                file2<<i->first<<"  ";
                vector<bool> x=i->second;
                for(int l=0;l<x.size();l++)
                file2<< x[l];
                file2<<endl;
            }
 
 
                                          //байт("ch")-номер элемента массива, добавляем +1 к элементу
        }
 
 
 
 
    return 0;
}
Если в краце это кодировка Хаффмана но выдает ошибку
- root 0xcdcdcdcd {num=??? cha=??? left=??? ...} Node *
num <Чтение памяти невозможно>
cha <Чтение памяти невозможно>

Ошибка по видимому в рекурсии но где?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 14:26. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru