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

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

Войти
Регистрация
Восстановить пароль
 
Золушка_я
0 / 0 / 0
Регистрация: 13.06.2016
Сообщений: 79
#1

Создать функцию, добавляющую столбец двухмерному динамическому массиву - C++

01.10.2016, 23:14. Просмотров 847. Ответов 1
Метки нет (Все метки)

Доброго времени суток, уважаемые форумчане! Помогите, пожалуйста, разобраться как написать функцию, удаляющую столбец двумерному динамическому массиву, в указанную пользователем позицию.
Знаю похожий пример, где удаляются столбы справа, но не пойму как это можно сделать на моем задании. Спасибо заранее за идеи и подсказки.
А вот пример программы, где с помощью функции удаляются столбцы справа. Ее основа годится для данного задания?
#include <iostream>
#include <cstdlib>
#include <random>
using std::cout;

int ** DeleleCol(int *** Array, int &x, int nDelCol);
int ** DeleleRow(int *** Array, int x, int &y, int nDelRow);

int main()
{
int n=5,m=4;
int ** Array;
Array=new int*[n];
for(int i=0;i<n;++i)
Array[i]=new int[m];


for(int i=0;i<m;++i){
for(int j=0;j<n;++j)
cout<<(Array[j][i]=rand()%100)<<"\t";
cout<<"\n";
}

cout<<"\n\n\n";
Array=DeleleRow(&Array,n,m,m-1);
for(int i=0;i<m;++i){
for(int j=0;j<n;++j)
cout<<Array[j][i]<<"\t";
cout<<"\n";
}

cout<<"\n\n\n";
Array=DeleleCol(&Array,n,n-1);
for(int i=0;i<m;++i){
for(int j=0;j<n;++j)
cout<<Array[j][i]<<"\t";
cout<<"\n";
}



for(int i=0;i<n;++i)
delete [] Array[i];
delete [] Array;
system("pause");
}




int ** DeleleCol(int *** Array, int &x, int nDelCol){
int ** tempArray=new int*[--x];

bool bFlag;
for(int i=0, bFlag=false;i<x;++i){
if(nDelCol==i) {bFlag=true; delete [] (*Array)[i];}
tempArray[i]=(bFlag)?(*Array)[i+1]*Array)[i];
}
delete [] (*Array);
return (*Array=tempArray);
}

int ** DeleleRow(int *** Array, int x, int &y, int nDelRow){
int * tempArray;
bool bFlag=false; --y;
for (int i=0;i<x;++i,bFlag=false){
tempArray=new int[y];
for(int j=0;j<y;++j){
if (nDelRow==j) {bFlag=true;}
tempArray[j]=(bFlag)?(*Array)[i][j+1]*Array)[i][j];
}
delete [] (*Array)[i];
(*Array)[i]=tempArray;
}
return *Array;
}
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.10.2016, 23:14
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Создать функцию, добавляющую столбец двухмерному динамическому массиву (C++):

Написать функцию, добавляющую столбец двухмерного массива по указанному номеру - C++
тема: Многомерные двухмерные массивы. Написать функцию, добавляющую столбец двухмерного массива по указанному номеру. Не могу решить...

Как с помощью указателя пройтись по двухмерному массиву? - C++
Всем привет. Подскажите плиз. Как с помощью указателя пройтись по двухмерному массиву и выдать значения елементов. есть массив int...

Поиск по динамическому массиву - C++
Задан целочисленный двумерный массив a из n строк и m столбцов. Найти номер последнего максимального значения среди нечетных (по значению)...

Доступ к динамическому массиву - C++
Первый раз столкнулся с такой фигней. Что происходит? #include &lt;iostream&gt; using namespace std; int main(int argc, char...

Добавление памяти динамическому массиву - C++
пытаюсь доканать динамические массивы (vector не предлагать, с ним все ок). суть задачи. есть массив структур, возникает необходимость...

Переход от статического к динамическому массиву - C++
Есть некая структура some_struct. Необходимо перейти от статического массива этих структур some_struct *Table; к динамическому ...

1
_stanislav
Рука
171 / 236 / 89
Регистрация: 16.08.2014
Сообщений: 1,126
Завершенные тесты: 2
02.10.2016, 13:34 #2
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Золушка_я,
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
#inlcude <iostream>
 
int* ErasePosition(int* array_, size_t size, size_t index)
{
    int* t = new int[size - 1];
    size_t i;
 
    for (i = 0; i < index; i++) t[i] = array_[i];
    for (i = index + 1; i < size; i++) t[i - 1] = array_[i];
 
    delete[] array_;
    return t;
}
int** EraseColumn(int** array_,
    size_t sizeRow, size_t sizeColumn, size_t indexColumn)
{
    int** t = new int*;
    for (size_t i = 0; i < sizeRow; i++)
    {
        t[i] = new int[sizeColumn - 1];
        t[i] = ErasePosition(array_[i], sizeColumn, indexColumn);
    }
 
    return t;
}
 
int main(int argc, char* argv[] )
{
    const size_t size = 3;
    int count = 1;
    int** t = new int*;
    for (size_t i = 0; i < size; i++)
        t[i] = new int[size];
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
            t[i][j] = count++;
 
    for (size_t i = 0; i < size; i++)
    {
        for (size_t j = 0; j < size; j++)
            std::cout << t[i][j] << ' ';
 
        std::cout << std::endl;
    }
 
    std::cout << std::endl;
 
    t = EraseColumn(t, size, size, 0);
 
    for (size_t i = 0; i < size; i++)
    {
        for (size_t j = 0; j < size; j++)
            std::cout << t[i][j] << ' ';
 
        std::cout << std::endl;
    }
 
    return 0;
}
Добавлено через 15 минут
Первый код с ошибкой. Вот второй вариант.
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
#include <iostream>
 
int* ErasePosition(int* array_, size_t size, size_t index)
{
    int* t = new int[size - 1];
    size_t i;
 
    for (i = 0; i < index; i++) t[i] = array_[i];
    for (i = index + 1; i < size; i++) t[i - 1] = array_[i];
 
    delete[] array_;
    return t;
}
int** EraseColumn(int** array_,
    size_t sizeRow, size_t sizeColumn, size_t indexColumn)
{
    int** t = new int*[sizeRow];
    for (size_t i = 0; i < sizeRow; i++)
    {
        t[i] = new int[sizeColumn - 1];
        t[i] = ErasePosition(array_[i], sizeColumn, indexColumn);
    }
 
    return t;
}
 
int main(int argc, char* argv[] )
{
    const size_t size = 3;
    int count = 1;
    int** t = new int*[size];
    for (size_t i = 0; i < size; i++)
        t[i] = new int[size];
 
    for (size_t i = 0; i < size; i++)
        for (size_t j = 0; j < size; j++)
            t[i][j] = count++;
 
    for (size_t i = 0; i < size; i++)
    {
        for (size_t j = 0; j < size; j++)
            std::cout << t[i][j] << ' ';
 
        std::cout << std::endl;
    }
 
    std::cout << std::endl;
 
    t = EraseColumn(t, size, size, 0);
 
    for (size_t i = 0; i < size; i++)
    {
        for (size_t j = 0; j < size; j++)
            std::cout << t[i][j] << ' ';
 
        std::cout << std::endl;
    }
 
    delete[] *t;
    delete[] t;
 
    return 0;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.10.2016, 13:34
Привет! Вот еще темы с ответами:

Нужен урок по одномерном и двумерному динамическому массиву - C++
Нужен урок по одномерном и двумерному динамическому массиву

Реализовать функцию, добавляющую в заданную строку рандомные элементы на нечётные позиции - C++
Например: Строка: Привет Строка после вставки элементов: 1Р4В7Т #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; ...

Реализовать функцию, считывающую из файла числа до конца, и добавляющую их в вектор (или в массив) - C++
Друзья, советуйте! Чтение из файла как процедура/функция -- важно. Спасибо Задача: Функция, которая считывает из файла числа до конца,...

Не могу разобраться как реализовать функцию инициализации даты по веденному массиву char - C++
//--------------------------------------------------------------------------- #pragma hdrstop ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru