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

При обращении к индексу двумерного массива char программа вылетает с ошибкой - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Установка различных модов на определенную игру http://www.cyberforum.ru/cpp-beginners/thread1227878.html
Все привет! Хочу написать программу, суть которой: Имеется база с различной информацией, которая постоянно обновляется. Пользователь может просматривать, оценивать, комментировать. В общем и целом...
C++ Задача на консольную графику, нарисовать круги программа взята с учебника, заголовочные файлы подключены, выдает 5 ошибок, но даже прочитать я их не могу, каракули какие-то... подскажите #include "stdafx.h" #include "msoftcon.h" // для... http://www.cyberforum.ru/cpp-beginners/thread1227858.html
Зачем нужны классы и структуры? C++
1. Зачем нужны классы? 2. Зачем нужны аргументы в main()? 3. Зачем нужны структуры. struct *имя*{}?
C++ Как в функции my_function преобразовать ссылку на базовый класс в ссылку на класс B или С
Всем привет, как в функции my_function преобразовать ссылку на базовый класс в ссылку на класс B или С ? class A { public: A(); ~A(); private: };
C++ Выбор кафедры в дальнейшей жизни: прикладное программирование VS системное программирование http://www.cyberforum.ru/cpp-beginners/thread1227819.html
Сразу извиняюсь что очень не по теме но всё же лучшего форума для этого вопроса я не нашел. Итак я вступаю во взрослую жизнь и давно определился с выбором факультета, но вот есть кафедры которые меня...
C++ Найти длину отрезка. Определить, в каких квадрантах координатной плоскости лежат его концы Помогите написать программу Задача Отрезок задан координатами концов. Вычислить его длину. Определить, в каких четвертях (квадрантах) координатной плоскости лежат его концы. Нужно написать... подробнее

Показать сообщение отдельно
andreyananas
22 / 22 / 9
Регистрация: 15.10.2013
Сообщений: 862
Завершенные тесты: 2

При обращении к индексу двумерного массива char программа вылетает с ошибкой - C++

16.07.2014, 00:46. Просмотров 281. Ответов 2
Метки (Все метки)

Программа вылетает с ошибкой на 66й строке. Почему?(((
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
// Task_1.cpp : Defines the entry point for the console application.
//
 
#include "stdafx.h"
#include <iostream>
using namespace std;
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    const int SIZE1 = 100;
    char Ar1[SIZE1], Ar2[SIZE1];
    cout << " Enter the string: ";
    cin.getline(Ar1, SIZE1);
 
    int nWords(0), index(0), MaxLenW(0);
    for (int i(0), temp(0); Ar1[i - 1] != '\0'; ++i) // 1) убираем лишние пробелы и 2) считаем количество слов в строке
    {
        if (Ar1[i] == ' ' && nWords == 0) // проверка на пробелы перед первым словом
            continue;
        else if (Ar1[i] == ' ' && Ar1[i + 1] == ' ') // проверка на два пробела между словами
            continue;
        else if (Ar1[i] == ' ' && Ar1[i + 1] == '\0') // проверка на пробел вконце строки
            continue;
        Ar2[index++] = Ar1[i]; // переписываем нужные символы строки
        if (Ar1[i] != ' ')
            ++temp;
        if (Ar1[i] != ' ' && Ar1[i + 1] == ' ' || Ar1[i] != ' ' && Ar1[i + 1] == '\0')// считаем количество слов 
        {
            ++nWords;
            if (temp > MaxLenW)
            {
                MaxLenW = temp; // считаем сколько символов в самом длинном слове
                temp = 0;
            }
            else
                temp = 0;
        }
    }
 
    //cout << Ar2 << endl;
    //cout << nWords << ' ' << MaxLenW << endl;
 
 
    /* 3) Найти самое длинное слово;
       4) Найти самое короткое слово;
       5) Вывести слова в обратном порядке;
       */
 
    char ** pAr3 = new char*[nWords];// выделяем память под указатель на указатели (по количеству слов)
    for (int i(0); i < nWords; ++i)
         pAr3[i] = new char[MaxLenW];//выделяем память под каждое слово с размером максимального слова
 
    //pAr3[0][2] = Ar2[0];
    //cout << pAr3[0][2];
 
    int index2(0), index2_1(0);
    for (int i(0); Ar2 != '\0'; ++i)
    {
        if (Ar2[i] == ' ')
        {
            ++index2;
            index2_1 = 0;
            continue;
        }
        pAr3[index2][index2_1] = Ar2[i];
    }
 
 
 
    for (int i(0); i < nWords; ++i)
        delete[] pAr3[i];
    delete[] pAr3;
 
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru