0 / 0 / 0
Регистрация: 29.09.2013
Сообщений: 27
1

Вставка нового столбца в двумерном массиве

13.12.2013, 21:50. Показов 1200. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Вставить новый столбец после столбца, в котором нет ни одного отрицательного элемента.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
13.12.2013, 21:50
Ответы с готовыми решениями:

Вставка нового элемента в произвольную допустимую позицию в массиве
Написать функции для работы с динамическим одномерным массивом: a) создание динамического массива...

Удаление столбца в двумерном динамическом массиве
Необходимо удалить столбец, содержащий хотя бы один ноль, из двумерного динамического...

В двумерном массиве найти среднее арифмитическое первого столбца...
Помогите пожлуйста нужно: задача №1 - В двумерном массиве найти среднее арифмитическое первого...

Выполнить в двумерном массиве поиск столбца с максимальной суммой элементов
Выполнить в двумерном массиве поиск столбца с максимальной суммой элементов.Помогите плиз с...

6
All rights reserved.
93 / 83 / 24
Регистрация: 03.08.2013
Сообщений: 258
14.12.2013, 03:48 2
Arseny242,
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
//StackOverflow
//All rights reserved.
 
#include <iostream>
#include <vector>
 
using namespace std;
 
int main()
{
    const int vectorSize = 5;
    vector< int > * vectorOfIntegers[ vectorSize ];
    vector<int> vectorOfIndexes;
 
    vectorOfIndexes.reserve( vectorSize );
 
    for ( int i = 0; i < vectorSize; i++ )
    {
        int number;
        vectorOfIntegers[ i ] = new vector< int >;
        vectorOfIntegers[ i ]->reserve( vectorSize );
 
        for ( int j = 0; j < vectorSize; j++ )
        {
            cin >> number;
            vectorOfIntegers[ i ]->push_back( number );
        }
    }
 
    for ( int i = 0; i < vectorSize; i++ )
    {
        bool columnHasNegativeElements = false;
 
        for ( int j = 0; j < vectorSize; j++ )
        {
            if ( vectorOfIntegers[ j ]->at( i ) < 0 )
            {
                columnHasNegativeElements = true;
                j = vectorSize;
            }
        }
 
        if ( columnHasNegativeElements == false )
        {
            vectorOfIndexes.push_back( i );
        }
    }
 
 
    if ( vectorOfIndexes.size() != 0 )
    {
        int n = 1;
 
        for ( int j = 0; j < vectorOfIndexes.size(); j++ )
        {
 
            for ( int i = 0; i < vectorSize; i++ )
            {
                std::vector<int>::iterator index = vectorOfIntegers[ i ]->begin();
 
                vectorOfIntegers[ i ]->insert( index + vectorOfIndexes[ j ] + n, 0 );
                
            }
            ++n;
        }
    }
 
    for ( int i = 0; i < vectorSize; i++ )
    {
        for ( int j = 0; j < (*vectorOfIntegers)->size(); j++ )
        {
            cout << vectorOfIntegers[ i ]->at( j ) << " ";
        }
 
        cout << endl;
    }
 
    return 0;
}
P.S. Размерности выбраны для удобства проверки. Можете их изменять, как хотите.
0
0 / 0 / 0
Регистрация: 29.09.2013
Сообщений: 27
14.12.2013, 15:21  [ТС] 3
Цитата Сообщение от StackOverflow Посмотреть сообщение
Arseny242,
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
//StackOverflow
//All rights reserved.
 
#include <iostream>
#include <vector>
 
using namespace std;
 
int main()
{
    const int vectorSize = 5;
    vector< int > * vectorOfIntegers[ vectorSize ];
    vector<int> vectorOfIndexes;
 
    vectorOfIndexes.reserve( vectorSize );
 
    for ( int i = 0; i < vectorSize; i++ )
    {
        int number;
        vectorOfIntegers[ i ] = new vector< int >;
        vectorOfIntegers[ i ]->reserve( vectorSize );
 
        for ( int j = 0; j < vectorSize; j++ )
        {
            cin >> number;
            vectorOfIntegers[ i ]->push_back( number );
        }
    }
 
    for ( int i = 0; i < vectorSize; i++ )
    {
        bool columnHasNegativeElements = false;
 
        for ( int j = 0; j < vectorSize; j++ )
        {
            if ( vectorOfIntegers[ j ]->at( i ) < 0 )
            {
                columnHasNegativeElements = true;
                j = vectorSize;
            }
        }
 
        if ( columnHasNegativeElements == false )
        {
            vectorOfIndexes.push_back( i );
        }
    }
 
 
    if ( vectorOfIndexes.size() != 0 )
    {
        int n = 1;
 
        for ( int j = 0; j < vectorOfIndexes.size(); j++ )
        {
 
            for ( int i = 0; i < vectorSize; i++ )
            {
                std::vector<int>::iterator index = vectorOfIntegers[ i ]->begin();
 
                vectorOfIntegers[ i ]->insert( index + vectorOfIndexes[ j ] + n, 0 );
                
            }
            ++n;
        }
    }
 
    for ( int i = 0; i < vectorSize; i++ )
    {
        for ( int j = 0; j < (*vectorOfIntegers)->size(); j++ )
        {
            cout << vectorOfIntegers[ i ]->at( j ) << " ";
        }
 
        cout << endl;
    }
 
    return 0;
}
P.S. Размерности выбраны для удобства проверки. Можете их изменять, как хотите.

А можно сделать эту задачу без векторов?
0
57 / 57 / 10
Регистрация: 08.12.2013
Сообщений: 257
14.12.2013, 15:22 4
Цитата Сообщение от Arseny242 Посмотреть сообщение
А можно сделать эту задачу без векторов?
правильно мыслишь
0
All rights reserved.
93 / 83 / 24
Регистрация: 03.08.2013
Сообщений: 258
14.12.2013, 20:36 5
Arseny242, можно. Только придётся делать временную копию массива, самому перевыделять память для столбцов, затем копировать элементы из временного массива обратно в исходный, не забывая при этом зарезервировать столбик, который был добавлен. Чем вам векторы не угодили?
0
0 / 0 / 0
Регистрация: 29.09.2013
Сообщений: 27
14.12.2013, 21:24  [ТС] 6
Цитата Сообщение от StackOverflow Посмотреть сообщение
Arseny242, можно. Только придётся делать временную копию массива, самому перевыделять память для столбцов, затем копировать элементы из временного массива обратно в исходный, не забывая при этом зарезервировать столбик, который был добавлен. Чем вам векторы не угодили?
Дело в том, что векторами я никогда не пользовался, и ничего про них не знаю.
0
All rights reserved.
93 / 83 / 24
Регистрация: 03.08.2013
Сообщений: 258
14.12.2013, 21:28 7
Arseny242, это не повод их избегать.
0
14.12.2013, 21:28
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
14.12.2013, 21:28
Помогаю со студенческими работами здесь

Функция для нахождение минимального значения каждого столбца в двумерном массиве
Как создать функцию, код, который в строчках 41 - 55 Спасибо заранее!!! #include &lt;stdio.h&gt;...

В двумерном массиве найти среднее арифметическое первого столбца и количество элементов
В двумерном массиве найти среднее арифметическое первого столбца и количество элементов в каждом из...

Нахождение номера столбца с максимальной серией одинаковых элементов в двумерном массиве
Подскажите чайнику: Сейчас учусь на заочке на первом курсе, изучаю С++. задача такая: 1. В...

В двумерном массиве определить для каждого столбца сумму минимального и максимального элементов
Дан двумерный массив из 5 строк и 6 столбцов. Определить для каждого столбца массива сумму...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru