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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
zewer
1083 / 774 / 76
Регистрация: 07.01.2011
Сообщений: 5,710
#1

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

19.03.2014, 23:20. Просмотров 426. Ответов 4
Метки нет (Все метки)

Добрый вечер форумчане. Написал програмку, все отлично, все работает. Но при завершении программы, т.е. когда выполняеться строчка
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;
}
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.03.2014, 23:20     Stack around the variable 'stat_c1' was corrupted
Посмотрите здесь:

C++ Stack around the variable 'b' was corrupted
stack around the variable was corrupted C++
C++ Бинарные файлы и Stack around the variable was corrupted
Stack around the variable 's' was corrupted C++
C++ Stack around the variable was corrupted
Run-Time Check Failure #2 - Stack around the variable 'n' was corrupted C++
C++ Stack around the variable 'cif' was corrupted
C++ stack around the variable was corrupted масив через указатель
C++ Stack around the variable was corrupted
Run-Time Check Failure #2 - Stack around the variable 'C' was corrupted C++
C++ Строка как массив символов. Stack around the variable 'qu' was corrupted
C++ Ошибка: Stack around the variable 'Material' was corrupted

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Людвиг Бодмер
307 / 304 / 108
Регистрация: 29.03.2013
Сообщений: 764
Завершенные тесты: 2
20.03.2014, 11:39     Stack around the variable 'stat_c1' was corrupted #2
zewer, вот в этих строках выход за пределы массива:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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;
            }
        }
    }
stat_c2[26] получается на последней итерации цикла. И дальше в следующем цикле то же самое
Tulosba
:)
Эксперт С++
4387 / 3230 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
20.03.2014, 11:54     Stack around the variable 'stat_c1' was corrupted #3
zewer, я в лёгком шоке от кода. Особенно от строк 28-79, 95-146, 204-255.... это ж надо было не полениться.

Первые два куска можно заменить на:
C++
1
stat_c1[ c1[i]-'a' ]++;
Последний на:
C++
1
2
3
4
5
6
7
8
for( int j=0; j<26; ++j )
{
   if (c2[i] == stat_c2_w[j]) 
   {
      c2[i] = stat_c1_w[j];
      break;
   }
}
Есть и ещё замечания, если соизволите послушать
castaway
Эксперт С++
4873 / 3012 / 370
Регистрация: 10.11.2010
Сообщений: 11,063
Записей в блоге: 10
Завершенные тесты: 1
20.03.2014, 12:14     Stack around the variable 'stat_c1' was corrupted #4
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Выход за пределы начинается с самого первого цикла (20-21 строки).
zewer
1083 / 774 / 76
Регистрация: 07.01.2011
Сообщений: 5,710
20.03.2014, 16:02  [ТС]     Stack around the variable 'stat_c1' was corrupted #5
Цитата Сообщение от castaway Посмотреть сообщение
Выход за пределы начинается с самого первого цикла (20-21 строки).
да, действительно, я инициализировал неизвестный элемент, спасибо

Добавлено через 42 секунды
Цитата Сообщение от Людвиг Бодмер Посмотреть сообщение
zewer, вот в этих строках выход за пределы массива
к сожелению вы не угадали

Добавлено через 2 минуты
Цитата Сообщение от Tulosba Посмотреть сообщение
stat_c1[ c1[i]-'a' ]++;
к сожелению я только новичек, таким приемом вобше не владею.
Да, я знаю что код говно, но я делал обычную лабу, смысл из которой был эфективно реализировать криптоанализ текста из 300 тисяч символов, качество расшифровки было 100%, чем и доволен, а сам код так то да, учусь только качественно програмировать )))
спасибо
Yandex
Объявления
20.03.2014, 16:02     Stack around the variable 'stat_c1' was corrupted
Ответ Создать тему
Опции темы

Текущее время: 12:19. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru