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

Динамический массив - C++

Восстановить пароль Регистрация
 
nekitko
Сообщений: n/a
01.06.2013, 22:21     Динамический массив #1
Доброе время суток) Я почти полный нуб , поэтому сразу прошу прощения Я хочу создать такой массив, размер которого увеличивается с каждым полученным значением. Вот такой код, который вообще то должен 1) запоминать значения пока не получит значение "0" 2) вывести массив на экран
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
using namespace std;
int main ()
{
    int n;
    int *mas = new int [n];
    n = 1;
    for (int i = 0; i<n; i++)       
    {
        if (n !=0) {
        cin >> mas [i]; n++;} else {cin >> mas [i]; break;}
    }
    for  (int i =0; i<n; i++) 
    {
        cout << mas[i] << "  ";
    }
    return 0;
}
Но на выходе получаем runtime error. Возможно, все, что на верху бред. Или ошибка. Но мне хотелось узнать как написать код, выполняющий описанный алгоритм. Please
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.06.2013, 22:21     Динамический массив
Посмотрите здесь:

C++ статический массив ----> динамический массив
динамический массив C++
динамический массив C++
C++ динамический массив
динамический массив в С++ C++
Динамический массив C++
C++ Динамический массив
Динамический массив C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Tulosba
:)
Эксперт С++
4378 / 3221 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
02.06.2013, 10:44     Динамический массив #2
nekitko, можно просто использовать std::vector. Но если хочется реализовать самому, то поищите "массив переменной длины".
По Вашему коду:
1. В 6 строке Вы выделяете память для n элементов. Но только вот само число n не инициализировано, поэтому уже ошибка.
2. Условие в цикле (строка 10) нелепое, т.к. если Вы попали в цикл, то n уже больше 0, к тому же Вы его изменили на 1 в 7 строке (что тоже не понятно зачем сделано).
3. Сам цикл будет бесконечным (или пока n не переполнится), т.к. идет инкремент i, и n, т.е. условие продолжения цикла будет такое ( i < i+1 ), что всегда истинно.
4. Вывод 13-16 строки был бы нормальным, если бы Вы не изменили n, и не зациклились в предыдущем цикле.
Yandex
Объявления
02.06.2013, 10:44     Динамический массив
Ответ Создать тему
Опции темы

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