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

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

Войти
Регистрация
Восстановить пароль
 
Andrey619
1 / 1 / 0
Регистрация: 16.04.2013
Сообщений: 49
#1

Удалить нечётные строки двумерного массива (динамический массив) - C++

12.06.2014, 17:47. Просмотров 371. Ответов 5
Метки нет (Все метки)

Требуется написать программу:
1. Удалить все нечётные строки двумерного массива.
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#include <iostream>
#include <ctime>
using namespace std;
 
int main()
{
    setlocale(LC_ALL,"rus");
    srand(time(0));
    int n,m;// коли-во строк и столбцов
    int arr1[20][20];
    int arr2[20][20];
    cout<<"Введите кол-во строк: ";
    cin>>n;
    cout<<"Введите кол-во столбцов: ";
    cin>>m;
    if(n==1)
        cout<<"Ошибка. Число строк = 1."<<endl;
    else{
        for (int i = 0; i < n; i++)
        {
            for (int j = 0; j < m; j++)
                arr1[i][j]=rand()%100;
        }
        cout<<"Исходный массив: "<<endl;
        for (int i = 0; i < n; i++)
        {
            for (int j = 0; j < m; j++)
                cout<<arr1[i][j]<<" ";
            cout<<endl;
        }   
        int k=0;
        for (int i = 0; i < n; i++)
        {
            if((i+1)%2==0)
            {
            for (int j = 0; j < m; j++)
                arr2[k][j]=arr1[i][j];
            k++;
            }
        }
        cout<<"\nМассив после удаления нечетных строк:"<<endl;
        for (int i = 0; i < k; i++)
        {
            for (int j = 0; j < m; j++)
                cout<<arr2[i][j]<<" ";
            cout<<endl;
        }
        int max,row=0;
        max=arr2[0][0];
        for (int i = 0; i < k; i++)//поиск max
        {           
            for (int j = 0; j < m; j++)
            {               
                if(max<arr2[i][j])
                {
                    max=arr2[i][j];
                    row=i;
                }
            }
        }
 
        if(row<k-1)
        {   
            for (int i = k-1; i > row; i--)
                for (int j = 0; j < m; j++)
                    arr2[i+1][j]=arr2[i][j];
            for (int j = 0; j < m; j++)/*генерация новой строки*/
                    arr2[row+1][j]=rand()%100;
        }
        else
            for (int j = 0; j < m; j++)
                    arr2[k][j]=rand()%100;  
        cout<<"\nДобавления строки после Максимального эл.:"<<endl;
        for (int i = 0; i < k+1; i++)
        {
            for (int j = 0; j < m; j++)
                cout<<arr2[i][j]<<" ";
            cout<<endl;
        }
    }
    system("pause");
    return 0;
}
Буду очень благодарен, за содействие
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.06.2014, 17:47
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Удалить нечётные строки двумерного массива (динамический массив) (C++):

Удалить все нечётные строки двумерного массива - C++
Задан двумерный массив чисел. Требуется написать программу: 1. Удалить все нечётные строки двумерного массива. 2. После той строки,...

Удалить строки двумерного массива - C++
должна удалять строку двумерного массива в которой нет четных элементов. у меня есть прога но она выдает ошибку, ошибка во время исполнения...

Удалить все непарные строки двумерного массива - C++
Написать в одной программе: 1. Удалить все непарные строки двумерного массива. 2. Добавить строку после той строки, которая содержит...

Составить программу, в которой создать динамический массив указателей для сохранения двумерного массива В с N × N целых - C++
Составить программу, в которой создать динамический массив указателей для сохранения двумерного массива В с N × N целых чисел, организовать...

1. Написать функцию проверяющую есть ли отрицательные элементы в указанной строке двумерного массива. Удалить из массива все строки с отрицательными э - C++
1. Написать функцию проверяющую есть ли отрицательные элементы в указанной строке двумерного массива. Удалить из массива все строки с...

Написать функцию проверяющую есть ли отрицательные элементы в указанной строке двумерного массива. Удалить из массива все строки с отрицательными элем - C++
Написать функцию проверяющую есть ли отрицательные элементы в указанной строке двумерного массива. Удалить из массива все строки с...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Тамика
Котовчанин
870 / 450 / 143
Регистрация: 16.02.2010
Сообщений: 2,978
Записей в блоге: 27
12.06.2014, 17:50 #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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include <iostream>
#include <ctime>
using namespace std;
 
int main()
{
    setlocale(LC_ALL,"rus");
    srand(time(0));
    int n,m;// коли-во строк и столбцов
    int **arr1 = new int*[20];
    for (int i = 0; i < 20; ++i)
        arr1[i] = new int[20];
 
    int **arr2 = new int*[20];
    for (int i = 0; i < 20; ++i)
        arr1[i] = new int[20];
 
    cout<<"Введите кол-во строк: ";
    cin>>n;
    cout<<"Введите кол-во столбцов: ";
    cin>>m;
    if(n==1)
        cout<<"Ошибка. Число строк = 1."<<endl;
    else{
        for (int i = 0; i < n; i++)
        {
            for (int j = 0; j < m; j++)
                arr1[i][j]=rand()%100;
        }
        cout<<"Исходный массив: "<<endl;
        for (int i = 0; i < n; i++)
        {
            for (int j = 0; j < m; j++)
                cout<<arr1[i][j]<<" ";
            cout<<endl;
        }   
        int k=0;
        for (int i = 0; i < n; i++)
        {
            if((i+1)%2==0)
            {
            for (int j = 0; j < m; j++)
                arr2[k][j]=arr1[i][j];
            k++;
            }
        }
        cout<<"\nМассив после удаления нечетных строк:"<<endl;
        for (int i = 0; i < k; i++)
        {
            for (int j = 0; j < m; j++)
                cout<<arr2[i][j]<<" ";
            cout<<endl;
        }
        int max,row=0;
        max=arr2[0][0];
        for (int i = 0; i < k; i++)//поиск max
        {           
            for (int j = 0; j < m; j++)
            {               
                if(max<arr2[i][j])
                {
                    max=arr2[i][j];
                    row=i;
                }
            }
        }
 
        if(row<k-1)
        {   
            for (int i = k-1; i > row; i--)
                for (int j = 0; j < m; j++)
                    arr2[i+1][j]=arr2[i][j];
            for (int j = 0; j < m; j++)/*генерация новой строки*/
                    arr2[row+1][j]=rand()%100;
        }
        else
            for (int j = 0; j < m; j++)
                    arr2[k][j]=rand()%100;  
        cout<<"\nДобавления строки после Максимального эл.:"<<endl;
        for (int i = 0; i < k+1; i++)
        {
            for (int j = 0; j < m; j++)
                cout<<arr2[i][j]<<" ";
            cout<<endl;
        }
    }
 
    system("pause");
    delete []arr1;
    delete []arr2;
    
    return 0;
}
1
Andrey619
1 / 1 / 0
Регистрация: 16.04.2013
Сообщений: 49
12.06.2014, 18:00  [ТС] #3
Обьясните пожалуйста внесённые изменения, для получения динамического массива.
0
Тамика
Котовчанин
870 / 450 / 143
Регистрация: 16.02.2010
Сообщений: 2,978
Записей в блоге: 27
12.06.2014, 18:03 #4
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Создаём указатель на массив из 20 "указателей". А потом каждому из этих 20-ти указателей сетим еще 20 указателей. В итоге получаем 20 на 20 массив.
C++
1
2
3
4
5
6
7
    int **arr1 = new int*[20];
    for (int i = 0; i < 20; ++i)
        arr1[i] = new int[20];
 
    int **arr2 = new int*[20];
    for (int i = 0; i < 20; ++i)
        arr1[i] = new int[20];
Только я неверно удалила. В конце должно быть
C++
1
2
3
4
5
6
7
8
    for (int i = 0; i < 20; ++i)
        delete [] arr1[i];
 
    for (int i = 0; i < 20; ++i)
        delete [] arr1[i];
 
    delete []arr1;
    delete []arr2;
1
Andrey619
1 / 1 / 0
Регистрация: 16.04.2013
Сообщений: 49
12.06.2014, 18:12  [ТС] #5
Спасибо большое, осталось только проверить,разобраться и понять.
0
Тамика
Котовчанин
870 / 450 / 143
Регистрация: 16.02.2010
Сообщений: 2,978
Записей в блоге: 27
12.06.2014, 18:13 #6
Цитата Сообщение от Andrey619 Посмотреть сообщение
Спасибо большое, осталось только проверить,разобраться и понять.
Всегда пожалуйста.
Коль что - спрашивайте. Не стесняйтесь.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.06.2014, 18:13
Привет! Вот еще темы с ответами:

Динамический массив - удалить указанное количество элементов с хвоста массива - C++
Доброе время суток! Ребята, подскажите как реализовать это задание Описать массив указанного пользователем количества элементов. ...

Динамический массив - удалить указанное количество элементов с хвоста массива - C++
Доброе время суток Подскажите, как быть тут? Только на динамический массив перешел Первое задание было: Удалить указанное количество...

Как работает массив указателей на строки двумерного массива? - C++
Есть работающий код: void main() { int matrix; for(i = 0; i &lt; 3; i++) { for(int j = 0; j &lt; 5; j++) { matrix...

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


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
12.06.2014, 18:13
Ответ Создать тему
Опции темы

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