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

Обращение к элементам двухмерного динамического массива - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Тип контейнера как параметр шаблонной функции http://www.cyberforum.ru/cpp-beginners/thread919138.html
Добрый день. Подскажите, пожалуйста, можно ли передавать тип контейнера как параметр в шаблонную функцию? Если да, то как это делается? Есть функция (см. код ниже), и в результате хотелось бы, чтобы она могла работать со всеми контейнерами, имеющими метод push_back(). template<class T> ifstream fill_v(vector<T>& v, const string& from) { ifstream ifs(from); if (!ifs) throw...
C++ Кодирующие контейнеры? Существуют ли контейнеры, которые позволяют хранить N элементов за memory<O(N)? Именно на ходу. Скорость не так важна. http://www.cyberforum.ru/cpp-beginners/thread919126.html
C++ Хвостовая рекурсия
int fac_times (int n, int acc) { if (n == 0) return acc; else return fac_times(n - 1, acc * n); } int factorial (int n) { return fac_times (n, 1); }. Можно ли в хвостатом факториале избавиться от вспомогательной функции? Как?
C++ Контур пятиконечной звезды в программе Dev C++ 5.4.2
Здравствуйте, помогите пожалуйста сделать задание: нарисовать контур пятиконечной звезды средствами языка с++ Только нужно работать именно с новыми компиляторами (как Dev C++ 5.4.2) Заранее спасибо!
C++ TRY/CATCH http://www.cyberforum.ru/cpp-beginners/thread919100.html
Здравствуйте! У меня есть: MASS; для простоты пояснения, x=rand();y=rand(),znacheniye=rand(); Как игнорировать ошибки доступа? TRY{MASS=znacheniye;} catch(...){}
C++ функция удаления и добавления элементов. что не так с програмой? #include <iostream> using namespace std; struct node{ double a; double b; node *next;}; node *head= NULL; node *p, *tail; void add(int n){ int i; подробнее

Показать сообщение отдельно
120°
12 / 10 / 1
Регистрация: 01.07.2013
Сообщений: 62
07.07.2013, 15:07     Обращение к элементам двухмерного динамического массива
Строки в двумерном динамическом массиве расположены не вплотную друг к другу. Тогда почему чтобы получить значение из массива оператор ar[i][j] правильно обращается к нужному элементу?

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
#include <iostream>
using namespace std;
 
void PrintArray(int **ar, int rows, int cols);
 
int main() 
{
    int **ar;
    int rows, cols;
 
    cout << "Введите количество строк и столбцов: ";
    cin >> rows >> cols;
 
    ar = new int*[rows];
    for (int i = 0; i < rows; i++)
        ar[i] = new int[cols];
 
    for (int i = 0; i < rows; i++)
        for (int j = 0; j < cols; j++)
            ar[i][j] = i + j;
 
    PrintArray(ar, rows, cols); 
 
    for (int i = 0; i < rows; i++)
        delete [] ar[i];
    delete [] ar;
    
    system("pause");
    return 0;
}
 
void PrintArray(int **ar, int rows, int cols)
{
    for (int i = 0; i < rows; i++)
    {
        for (int j = 0; j < cols; j++)
            cout << ar[i][j];       // ????
 
        cout << endl;
    }
}
Добавлено через 2 минуты
и еще один вопрос по массивам, что то не понимаю этого. если поставить круглые скобки при создании, то выдает ошибку. почему?
C++
1
ar = new (int*)[rows];
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 05:36. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru