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

Подправить код в двумерном массиве - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ (матрица)Почему ошибка в if? http://www.cyberforum.ru/cpp-beginners/thread898455.html
int d=1;k=0; for(j=k;j<d;j++,d++) for(i=0;i<n;i++) {if(a%2!=0)// Здесь ошибка
C++ Сортировать матрицу Сортировать матрицу таким образом, чтобы сначала располагались все серии из одинаковых элементов, а затем - все остальные элементы. http://www.cyberforum.ru/cpp-beginners/thread898454.html
Алгоритм имитации отжига при решении задачи размещения электронных схем C++
Подгоните примерчик пожалуйста на такую тему для саморазбора
C++ обработка исключительных ситуаций
Необходимо реализовать обработку исключительных ситуаций в програм- ме, в котором реализуется циклический алгоритм вычисления вектора значений функции f(x) (таблица 14.1). На дисплей в цикле...
C++ Сформировать массивы: ординаты точек, которые находятся в первом / третьем квадранте и их количество http://www.cyberforum.ru/cpp-beginners/thread898438.html
Даны координаты точек х1, у1, х2, у2,... х15, у15. Сформировать и вывести на печать два массива: А - ординаты точек, которые находятся в первом квадранте, и их количество; массив В - абсциссы точек,...
C++ Нотация указателей Преподователь попросил применить нотацию указателей вместо нотации массивов, помогите пожалуйста. Вот мой код #include <iostream> using namespace std; int main() { setlocale(0,"rus");... подробнее

Показать сообщение отдельно
MikeEl
1 / 1 / 0
Регистрация: 27.03.2012
Сообщений: 52

Подправить код в двумерном массиве - C++

11.06.2013, 13:09. Просмотров 178. Ответов 0
Метки (Все метки)

Есть задание:
В матрице из целых чисел поменять местами первую строку и строку, содержащую самый большой по абсолютной величине элемент матрицы.
есть рабочий код:
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
#include <iostream>
#include <cstdlib>
#include <ctime>
 using namespace std;
int** init_arr(unsigned x, unsigned y)
{
    srand(time(0));
    int** base = new int*[x];
    for (unsigned i = 0; i < x; ++i)
    {
        base[i] = new int[y];
        for (unsigned j = 0; j < y; ++j)
        {
            base[i][j] = rand() % 100;
        }
    }
    return base;
}
 
void free_arr(int** base, unsigned x)
{
 
    for (unsigned i = 0; i < x; ++i)
    {
        delete [] base[i];
    }
    delete [] base;
}
 
void show_arr(int** base, unsigned x, unsigned y)
{
    for (unsigned i = 0; i < x; ++i)
    {
        for (unsigned j = 0; j < y; ++j)
        {
            cout.width(3);
            cout.setf(ios::left);
            cout << base[i][j] << ' ';
        }
        cout << '\n';
    }
}
 
void swap_first_line(int** arr, unsigned x, unsigned y)
{
    int** max_line = arr;
    int max_elem = arr[0][0];
    for (unsigned i = 0; i < x; ++i)
    {
        for (unsigned j = 0; j < y; ++j)
        {
            if (max_elem < arr[i][j])
            {
                max_elem = arr[i][j];
                if (*max_line != arr[i])
                {
                    max_line = &arr[i];
                }
            }
        }
    }
    int* tmp = arr[0];
    arr[0] = *max_line;
    *max_line = tmp;
}
 
int main()
{
    unsigned x, y;
    cout << "Put size of array [x][y]:\n";
    cout << "   x -> ";
    cin >> x;
    cout << "   y -> ";
    cin >> y;
 
    int** arr = init_arr(x, y);
    cout << "\nWe have array:\n";
    show_arr(arr, x, y);
    swap_first_line(arr, x, y);
    cout << "\nAfter swap:\n";
    show_arr(arr, x, y);
    system("pause");
    free_arr(arr, x);
}
как можно его улучшить и оптимизировать. в особенности интересуют первые двуе функции:
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
int** init_arr(unsigned x, unsigned y)
{
    srand(time(0));
    int** base = new int*[x];
    for (unsigned i = 0; i < x; ++i)
    {
        base[i] = new int[y];
        for (unsigned j = 0; j < y; ++j)
        {
            base[i][j] = rand() % 100;
        }
    }
    return base;
}
 
void free_arr(int** base, unsigned x)
{
 
    for (unsigned i = 0; i < x; ++i)
    {
        delete [] base[i];
    }
    delete [] base;
}
и использование еще одной функции здесь:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int main()
{
    unsigned x, y;
    cout << "Put size of array [x][y]:\n";
    cout << "   x -> ";
    cin >> x;
    cout << "   y -> ";
    cin >> y;
 
    int** arr = init_arr(x, y);
    cout << "\nWe have array:\n";
    show_arr(arr, x, y);
    swap_first_line(arr, x, y);
    cout << "\nAfter swap:\n";
    show_arr(arr, x, y);
    system("pause");
    free_arr(arr, x);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru