Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 13.02.2018
Сообщений: 17

Удалить наибольший элементов каждого столбца матрицы

13.02.2018, 23:22. Показов 713. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Товарищи программисты! Прошу вас помочь мне. Заранее благодарю.
Никак не могу найти ошибку в данном коде.
Мой друг компилятор говорит о следующем: "Вызвано исключение по адресу 0x010925D8 в ConsoleApplication171.exe: 0xC0000005: нарушение прав доступа при чтении по адресу 0xCDCDCDCD.
".
А задание звучит так: Сформировать в динамической памяти целочисленную матрицу (N+1)*N. Получить квадратную матрицу порядка N путем удаления наибольших элементов каждого столбца, сохраняя при этом порядок остальных. Вывести на экран исходную и полученную матрицы.
P.S Я впервые пишу на данный форум и без понятия как прикреплять код, поэтому заранее прошу прощения, если не выйдет.
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
#include "stdafx.h"
#include<iostream>
#include<ctime>
#include<conio.h>
 
using namespace std;
 
int searchmax(int n, int **a, int j)
{
    int max;
    int k;
    max = **a;
    for (int i = 0; i < n + 1;i++)
    {
        if (*(*(a + i) + j) > max)
        {
            max = *(*(a + i) + j);
            k = i;
 
        }
    }
    return(k);
}
void sdvig(int n, int **a, int k, int j)
{
    for (int i = k;i < n + 1;i++)
        *(*(a + i) + j) = *(*(a + i + 1) + j);
}
void main()
{
    srand(time(NULL));
    int n = 0;
    cin >> n;
    int **a = new int*[n + 1];
    for (int i = 0; i < n; i++)
    {
        a[i] = new int[n + 1];
    }
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            *(*(a + i) + j) = rand() % 10;
            cout << *(*(a + i) + j) << " ";
        }
        cout << "\n";
    }
 
    cout << "\n";
    int k = 0;
    for (int j = 0;j < n;j++)
    {
        k = searchmax(n, a, j);
        cout << " max in " << j << " stolbze: " << *(*(a + k) + j);
 
        sdvig(n, a, k, j);
 
    }
    cout << "\n";
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            *(*(a + i) + j) = rand() % 10;
            cout << *(*(a + i) + j) << " ";
        }
        cout << "\n";
    }
    for (int i = 0;i < n;i++)
        delete[] a[i];
    _getch();
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.02.2018, 23:22
Ответы с готовыми решениями:

Переписать наибольший по абсолютной величине элемент каждого столбца матрицы D(m,n) в одномерный массив G
Подскажите, пожалуйста, почему 1й элемент массива G выводится как 0? #include &lt;iostream&gt; using namespace std; int main() {...

Определить сумму элементов каждого столбца левой половины и сумму элементов каждого четного столбца правой половины матрицы A
Матрица A (M кратно 4) разделена по вертикали на две половины. Определить сумму элементов каждого столбца левой половины и сумму элементов...

Получить новую матрицу путем вычитания от элементов каждого столбца первой матрицы суммы элементов соответствующих строк второй матрицы
Даны две целочисленные квадратные матрицы 4-го порядка. Получить новую матрицу путем вычитания от элементов каждого столбца первой матрицы...

8
 Аватар для Hitoku
1755 / 1347 / 1407
Регистрация: 28.10.2016
Сообщений: 4,267
13.02.2018, 23:28
C++
10
11
12
int max;
...
max = **a;
ничего не смущает?
0
0 / 0 / 0
Регистрация: 13.02.2018
Сообщений: 17
13.02.2018, 23:42  [ТС]
Меня смущает тут буквально все...
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
14.02.2018, 00:45

Не по теме:

Цитата Сообщение от Ольга_98 Посмотреть сообщение
Меня смущает тут буквально все...
Аж до румянца на щеках? ;)



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
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
 
int max_column_index(int ** matrix, int rows, int col) {
    int mi = 0;
    
    for ( int i = 1; i < rows; ++i )
        if ( matrix[i][col] > matrix[mi][col] )
            mi = i;
    
    return mi;
}
 
void dump_matrix(int ** matrix, int rows, int columns) {
    for ( int i = 0; i < rows; ++i ) {
        for ( int j = 0; j < columns; ++j ) 
            std::cout << std::setw(3) << matrix[i][j];
        std::cout << std::endl;
    }
}
 
int main() {
    int n;
    
    std::cout << "N = ";
    std::cin >> n;
    
    int ** m1 = new int* [ n + 1 ];
    for ( int i = 0; i < n + 1; ++i )
        m1[i] = new int [ n ];
    
    srand(time(NULL));
    
    for ( int i = 0; i < n + 1; ++i )
        for ( int j = 0; j < n; ++j )
            m1[i][j] = rand() % 100;
    
    int ** m2 = new int* [ n ];
    for ( int i = 0; i < n; ++i )
        m2[i] = new int [ n ];
    
    for ( int j = 0; j < n; ++j ) {
        int mi = max_column_index(m1, n + 1, j);
        int ii = 0;
        
        for ( int i = 0; i < n + 1; ++i ) {
            if ( i == mi )
                continue;
            m2[ii++][j] = m1[i][j];
        }
    }
    
    std::cout << "First matrix:" << std::endl;
    dump_matrix(m1, n + 1, n);
    
    std::cout << "\nSecond matrix:" << std::endl;
    dump_matrix(m2, n, n);
    
    for ( int i = 0; i < n + 1; ++i )
        delete [] m1[i];
    delete [] m1;
    
    for ( int i = 0; i < n; ++i )
        delete [] m2[i];
    delete [] m2;
    
    return 0;
}
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
[andrew@easybook numbers]$ g++ -Wall matrix_n_1.cpp 
[andrew@easybook numbers]$ ./a.out 
N = 5
First matrix:
  9  5 86 41 79
 91 36  9 80 27
 11 46 41 89 24
 27 56 37 75 11
 34 65 36 68 92
 74 91 10 38  5
 
Second matrix:
  9  5  9 41 79
 11 36 41 80 27
 27 46 37 75 24
 34 56 36 68 11
 74 65 10 38  5
[andrew@easybook numbers]$
1
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
14.02.2018, 02:09
как вариант:

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
#include <iostream>
#include <ctime>
using namespace std;
 
int main()
{       
   srand(time(0)); // генерация случайных чисел
   int N, max=0, imax;
   cout <<"N="; cin >>N;   
   
// объявление двумерных динамических массивов
 
   int **a = new int* [N+1]; 
   for (int i = 0; i < N+1; i++)
        a[i] = new int [N];
        
   int **b = new int* [N]; 
   for (int i = 0; i < N; i++)
        b[i] = new int [N];    
        
    
// заполнение массива случайными числами от 1 до 9 и вывод на экран
   
    cout <<"Matrix 1:\n"; 
    for (int i = 0; i < N+1; i++)
        {
        for (int j = 0; j < N; j++)
        {
            a[i][j] = rand() %9 + 1;
            cout << a[i][j] << " ";            
        }        
            cout <<endl;            
        }
        
// определение последнего max столбца и сдвиг элементов
 
      for (int j = 0; j < N; j++)
        {
        for (int i = 0; i < N+1; i++)            
            if (i==0 ||a[i][j] >= max) 
            {
            max = a[i][j];
            imax=i;
            }
            for (int k = imax; k < N; k++)
            a[k][j]=a[k+1][j];              
        }
        cout <<endl;
        
// заполнение и вывод нового массива
 
        cout <<"Matrix 2:\n";
        for (int i = 0; i < N; i++)
        {
        for (int j = 0; j < N; j++) 
        {
        b[i][j]=a[i][j];
        cout << b[i][j] << " ";
        }
        cout <<endl;            
        }        
        
// освобождение памяти отведённой под массивы:
 
    for (int i = 0; i < N+1; i++)
    delete [] a[i];
    delete [] a;
    for (int i = 0; i < N; i++)
    delete [] b[i];
    delete [] b; 
system("pause");
return 0;
}
если максимумов в столбце несколько - удалит последний их них

p.s. в задании не сказано чётко, нужно организовать новую матрицу или преобразовать исходную. это вариант программы с организацией новой матрицы. если нужно по-другому - сообщите.
0
0 / 0 / 0
Регистрация: 13.02.2018
Сообщений: 17
14.02.2018, 12:28  [ТС]
easybudda, премного благодарна за сей код, работает отменно. Но можно ли уточнить у вас по поводу доступа к элементам матрицы при помощи адресной арифметики: будет ли изменено что-нибудь в коде помимо вида самих элементов? И хотелось бы узнать в чем состояла ошибка конкретно в моем коде, чтоб предотвратить появление таких же оплошностей в дальнейшем.
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
14.02.2018, 18:29
Цитата Сообщение от Ольга_98 Посмотреть сообщение
Но можно ли уточнить у вас по поводу доступа к элементам матрицы при помощи адресной арифметики: будет ли изменено что-нибудь в коде помимо вида самих элементов?
Ничего не понял! Какой вид элементов?

Цитата Сообщение от Ольга_98 Посмотреть сообщение
И хотелось бы узнать в чем состояла ошибка конкретно в моем коде
Крайне запутанные обращения к элементам, чувство такое, что Вы пытаетесь с матрицей, как с одним длинным сплошным массивом работать...

Плюс к тому: что по-вашему должна вернуть функция searchmax если вот это адское условие
Цитата Сообщение от Ольга_98 Посмотреть сообщение
if (*(*(a + i) + j) > max)
ни разу не отработает?
0
0 / 0 / 0
Регистрация: 13.02.2018
Сообщений: 17
14.02.2018, 23:09  [ТС]
easybudda, С первым вопросом я разобралась самостоятельно, но вот по поводу условия if (*(*(a + i) + j) > max) никак не пойму, хоть убей. Поясните мне что тут не так, пожалуйста.
0
 Аватар для Herji
299 / 208 / 174
Регистрация: 11.05.2016
Сообщений: 655
14.02.2018, 23:17
Цитата Сообщение от Ольга_98 Посмотреть сообщение
никак не пойму, хоть убей. Поясните мне что тут не так, пожалуйста.
Дело не в самом условии:
Цитата Сообщение от Ольга_98 Посмотреть сообщение
C++
1
2
int k;
max = **a;
C++
1
2
int k = 0;
max = **a;
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.02.2018, 23:17
Помогаю со студенческими работами здесь

Вычесть из каждого столбца матрицы максимальный элемент для каждого столбца, и результат вывести в матрицу
Что нужно добавить , чтобы вычесть из каждого столбца матрицы максимальный элемент для каждого столбца и результат вывести в матрицу? ...

Найти сумму элементов столбца матрицы, в котором расположится наибольший элемент
Помогите пож-та решить задачку: Найти сумму элементов того столбца двумерного массива, в котором расположится наибольший элемент (считаем,...

Даны две целочисленные матрицы 4-го порядка. Получить новую * матрицу путем вычитания из элементов каждого столбца первой матрицы
даны две целочисленные матрицы 4-го порядка. Получить новую матрицу путем вычитания из элементов каждого столбца первой матрицы сумму...

Получить новую матрицу прибавлением к элементам каждого столбца первой матрицы произведения элементов соответствующих строк второй матрицы
Даны две действительные квадратные матрицы порядка n. Получить новую матрицу прибавлением к элементам каждого столбца первой матрицы...

Среднее арифметическое элементов каждого столбца матрицы
Что не так? в SA выводит все элементы = 0 Задание: Найти среднее арифметическое элементов каждого столбца матрицы (3,4). Результат...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru