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

Stack around the variable 'stat_c1' was corrupted - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Класс памяти по умолчанию для глобальной переменной http://www.cyberforum.ru/cpp-beginners/thread1124478.html
Здравствуйте! Прочитала такую вещь тут Объявление переменных на глобальном уровне - это или определение переменных, или ссылки на определения, сделанные в другом месте программы. Объявление глобальной переменной, которое инициализирует эту переменную (явно или неявно), является определением переменной. Определение на глобальном уровне может задаваться в следующих формах: 1. Переменная...
C++ Заполнить рандомно массив и все отрицательные элементы отправить в конец В массиве A=(a1, а2, ..., аn) все отрицательные элементы отправить в «хвост» массива. ( Это задание) Вот сам код. // ConsoleApplication4234452.cpp: определяет точку входа для консольного приложения. // #include "stdafx.h" #include <iostream> #include "conio.h" #include <time.h> http://www.cyberforum.ru/cpp-beginners/thread1124460.html
C++ Реализовать метод приведения времени в минуты
Реализовать внешнюю функцию с именем make_mun(), где mun – тип реализуемой структуры. Функция должна получать в качестве аргументов значения для полей структуры и возвращать структуру требуемого типа. При передаче ошибочных параметров следует выводить сообщение и заканчивать работу. Поле first – целое положительное число, часы; поле second – целое положительное число, минуты. Реализовать метод...
C++ Структура-пара. Реализовать метод rangecheck() – проверку заданного числа
Реализовать внешнюю функцию с именем make_mun(), где mun – тип реализуемой структуры. Функция должна получать в качестве аргументов значения для полей структуры и возвращать структуру требуемого типа. При передаче ошибочных параметров следует выводить сообщение и заканчивать работу. Поле first – дробное число, левая граница диапазона; поле second – дробное число, правая граница диапазона....
C++ Определить, лежит ли точка внутри заштрихованной области http://www.cyberforum.ru/cpp-beginners/thread1124432.html
Дана точка на плоскости с координатами (х, у). Составить программу, которая выдает одно из сообщений «Да», «Нет», «На границе» в зависимости от того, лежит ли точка внутри заштрихованной области, вне заштрихованной области или на ее границе. График Помогите с кодом...
C++ Удалить подряд идущие одинаковые слова из строки Одна из ошибок, которую часто допускают неопытные наборщики - дважды написанное слово. Найти такие ошибки в заданном тексте и исправить их Помогите, пожалуйста. подробнее

Показать сообщение отдельно
zewer
 Аватар для zewer
1018 / 709 / 71
Регистрация: 07.01.2011
Сообщений: 5,346
19.03.2014, 23:20     Stack around the variable 'stat_c1' was corrupted
Добрый вечер форумчане. Написал програмку, все отлично, все работает. Но при завершении программы, т.е. когда выполняеться строчка
C++
1
return 0;
Выскакивает ошибка
Stack around the variable 'stat_c1' was corrupted
и
Stack around the variable 'stat_c2' was corrupted
Я знаю суть этих ошибок, это обращение к неизвестной итерации масива, но тут то программа закончила уже работу, и только тогда ошибка. С такими случаями не встречался, по этому прошу помощи у вас.

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
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
#include "iostream"
#include "fstream"
 
using namespace std;
 
//1.txt - original test
//2.txt - shifr_cesar text
//4.txt - roshifr text
 
char c1[999999];//1.txt
char c2[999999];//2.txt
 
 
int main()
{
    ifstream in("1.txt");//зчитування вхідного чистого тексту у масив с1
    in.getline(c1, 999999);
    int stat_c1[26];//"abcdefghijklmnopqrstuvwxyz" //статистика у цифрах
    char stat_c1_w[27] = { "abcdefghijklmnopqrstuvwxyz" };//статистика у буквах
    for (int i = 0; i < 27; i++)//ініціалізація
        stat_c1[i] = 0;
    int len_c1 = 0;//довжина вхідного чистого тексту
    for (int i = 0; c1[i] != '\0'; i++) //підрахунок к-сті повторень кожної літери окремо у вхідному чистому тексті
    {
        if (c1[i] != ' ')
        {
            len_c1++;
            if (c1[i] == 'a')
                stat_c1[0]++;
            if (c1[i] == 'b')
                stat_c1[1]++;
            if (c1[i] == 'c')
                stat_c1[2]++;
            if (c1[i] == 'd')
                stat_c1[3]++;
            if (c1[i] == 'e')
                stat_c1[4]++;
            if (c1[i] == 'f')
                stat_c1[5]++;
            if (c1[i] == 'g')
                stat_c1[6]++;
            if (c1[i] == 'h')
                stat_c1[7]++;
            if (c1[i] == 'i')
                stat_c1[8]++;
            if (c1[i] == 'j')
                stat_c1[9]++;
            if (c1[i] == 'k')
                stat_c1[10]++;
            if (c1[i] == 'l')
                stat_c1[11]++;
            if (c1[i] == 'm')
                stat_c1[12]++;
            if (c1[i] == 'n')
                stat_c1[13]++;
            if (c1[i] == 'o')
                stat_c1[14]++;
            if (c1[i] == 'p')
                stat_c1[15]++;
            if (c1[i] == 'q')
                stat_c1[16]++;
            if (c1[i] == 'r')
                stat_c1[17]++;
            if (c1[i] == 's')
                stat_c1[18]++;
            if (c1[i] == 't')
                stat_c1[19]++;
            if (c1[i] == 'u')
                stat_c1[20]++;
            if (c1[i] == 'v')
                stat_c1[21]++;
            if (c1[i] == 'w')
                stat_c1[22]++;
            if (c1[i] == 'x')
                stat_c1[23]++;
            if (c1[i] == 'y')
                stat_c1[24]++;
            if (c1[i] == 'z')
                stat_c1[25]++;
        }
    }
    
    ifstream in1("2.txt");//зчитування вхідного шифро тексту в масив с2
    in1.getline(c2, 999999);
    int stat_c2[26];//"abcdefghijklmnopqrstuvwxyz" //статистика у цифрах для шифро тексту
    char stat_c2_w[27] = { "abcdefghijklmnopqrstuvwxyz" };//статистика букв для шифротексту
    for (int i = 0; i < 27; i++)//ініціалізація
        stat_c2[i] = 0;
    int len_c2 = 0;//довжина шифро тексту
    for (int i = 0; c2[i] != '\0'; i++)//підрахунок к-сті повторень кожної літери окремо у шифротексті
    {
        if (c2[i] != ' ')
        {
            len_c2++;
            if (c2[i] == 'a')
                stat_c2[0]++;
            if (c2[i] == 'b')
                stat_c2[1]++;
            if (c2[i] == 'c')
                stat_c2[2]++;
            if (c2[i] == 'd')
                stat_c2[3]++;
            if (c2[i] == 'e')
                stat_c2[4]++;
            if (c2[i] == 'f')
                stat_c2[5]++;
            if (c2[i] == 'g')
                stat_c2[6]++;
            if (c2[i] == 'h')
                stat_c2[7]++;
            if (c2[i] == 'i')
                stat_c2[8]++;
            if (c2[i] == 'j')
                stat_c2[9]++;
            if (c2[i] == 'k')
                stat_c2[10]++;
            if (c2[i] == 'l')
                stat_c2[11]++;
            if (c2[i] == 'm')
                stat_c2[12]++;
            if (c2[i] == 'n')
                stat_c2[13]++;
            if (c2[i] == 'o')
                stat_c2[14]++;
            if (c2[i] == 'p')
                stat_c2[15]++;
            if (c2[i] == 'q')
                stat_c2[16]++;
            if (c2[i] == 'r')
                stat_c2[17]++;
            if (c2[i] == 's')
                stat_c2[18]++;
            if (c2[i] == 't')
                stat_c2[19]++;
            if (c2[i] == 'u')
                stat_c2[20]++;
            if (c2[i] == 'v')
                stat_c2[21]++;
            if (c2[i] == 'w')
                stat_c2[22]++;
            if (c2[i] == 'x')
                stat_c2[23]++;
            if (c2[i] == 'y')
                stat_c2[24]++;
            if (c2[i] == 'z')
                stat_c2[25]++;
        }
    }
    
    int tmp;//дод зміна для зберігання числа у сортуванні бульбашкою
    char tmp_w;//дод зміна для зберігання букви
    for (int i = 0; i < 26 - 1; i++)//сортування в порядку спадання частоти літер з вхідного чистого тексту
    {
        for (int j = 0; j < 26 - 1; j++) // 1.txt sort
        {
            if (stat_c1[j + 1] > stat_c1[j])//алгоритм бульбашки
            {
                tmp = stat_c1[j + 1];
                tmp_w = stat_c1_w[j + 1];
                stat_c1[j + 1] = stat_c1[j];
                stat_c1_w[j + 1] = stat_c1_w[j];
                stat_c1[j] = tmp;
                stat_c1_w[j] = tmp_w;
            }
        }
    }
 
    for (int i = 0; i < 26 - 1; i++)//сортування в порядку спадання частоти літер з шифротексту
    {
        for (int j = 0; j < 26 - 1; j++) // 2.txt sort
        {
            if (stat_c2[j + 1] > stat_c2[j])//алгоритм бульбашки
            {
                tmp = stat_c2[j + 1];
                tmp_w = stat_c2_w[j + 1];
                stat_c2[j + 1] = stat_c2[j];
                stat_c2_w[j + 1] = stat_c2_w[j];
                stat_c2[j] = tmp;
                stat_c2_w[j] = tmp_w;
            }
        }
    }
    
    /*-----------Збір статистики частоти завершено------------------*/
 
    //1.txt вхідний чистий текст
    /*stat_c1[26];//"abcdefghijklmnopqrstuvwxyz" // статистика
    stat_c1_w[27] = { "abcdefghijklmnopqrstuvwxyz" }; // букви статистики*/ 
    // c1[999999];//1.txt вхідний чистий текст
 
    /*---*/
 
    //2.txt вхідний шифротекст
    /*stat_c2[26];//"abcdefghijklmnopqrstuvwxyz" // статистика
    stat_c2_w[27] = { "abcdefghijklmnopqrstuvwxyz" }; // букви статистики*/
    //c2[999999];//2.txt вхідний шифротекст
 
    /*----------------Дешифрування-----------------*/
 
    for (int i = 0; c2[i] != '\0'; i++)//співставляння частот букв, та заміна їх, тобто процес дешифрування
    {
        if (c2[i] != ' ')
        {
            if (c2[i] == stat_c2_w[0])
                c2[i] = stat_c1_w[0];
            else if (c2[i] == stat_c2_w[1])
                c2[i] = stat_c1_w[1];
            else if (c2[i] == stat_c2_w[2])
                c2[i] = stat_c1_w[2];
            else if (c2[i] == stat_c2_w[3])
                c2[i] = stat_c1_w[3];
            else if (c2[i] == stat_c2_w[4])
                c2[i] = stat_c1_w[4];
            else if (c2[i] == stat_c2_w[5])
                c2[i] = stat_c1_w[5];
            else if (c2[i] == stat_c2_w[6])
                c2[i] = stat_c1_w[6];
            else if (c2[i] == stat_c2_w[7])
                c2[i] = stat_c1_w[7];
            else if (c2[i] == stat_c2_w[8])
                c2[i] = stat_c1_w[8];
            else if (c2[i] == stat_c2_w[9])
                c2[i] = stat_c1_w[9];
            else if (c2[i] == stat_c2_w[10])
                c2[i] = stat_c1_w[10];
            else if (c2[i] == stat_c2_w[11])
                c2[i] = stat_c1_w[11];
            else if (c2[i] == stat_c2_w[12])
                c2[i] = stat_c1_w[12];
            else if (c2[i] == stat_c2_w[13])
                c2[i] = stat_c1_w[13];
            else if (c2[i] == stat_c2_w[14])
                c2[i] = stat_c1_w[14];
            else if (c2[i] == stat_c2_w[15])
                c2[i] = stat_c1_w[15];
            else if (c2[i] == stat_c2_w[16])
                c2[i] = stat_c1_w[16];
            else if (c2[i] == stat_c2_w[17])
                c2[i] = stat_c1_w[17];
            else if (c2[i] == stat_c2_w[18])
                c2[i] = stat_c1_w[18];
            else if (c2[i] == stat_c2_w[19])
                c2[i] = stat_c1_w[19];
            else if (c2[i] == stat_c2_w[20])
                c2[i] = stat_c1_w[20];
            else if (c2[i] == stat_c2_w[21])
                c2[i] = stat_c1_w[21];
            else if (c2[i] == stat_c2_w[22])
                c2[i] = stat_c1_w[22];
            else if (c2[i] == stat_c2_w[23])
                c2[i] = stat_c1_w[23];
            else if (c2[i] == stat_c2_w[24])
                c2[i] = stat_c1_w[24];
            else if (c2[i] == stat_c2_w[25])
                c2[i] = stat_c1_w[25];
        }
    }
    
    //cout << "\t" << len_c1 << "\n\n";
    cout << "1.txt statistic:\t\t2.txt statistic\n";
    for (int i = 0; i < 26; i++)
        cout << stat_c1[i] << "---" << stat_c1_w[i] << "\t\t\t" << stat_c2[i] << "---" << stat_c2_w[i] << "\n";
    //cout << "2.txt statistic:\n";
    /*for (int i = 0; i < 26; i++)
        cout << stat_c2[i] << "---" << stat_c2_w[i] << "\n";*/
    /*int g = 0;
    for (int i = 0; i < 26; i++)
        g += stat_c1[i];*/
    //cout << "\t\t\n" << g << "\n";
 
    ofstream out("4.txt");//вивід результату в файл
    out << c2;
    
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 11:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru