Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
 Аватар для na3ar1y
48 / 4 / 3
Регистрация: 14.11.2010
Сообщений: 163

Алгоритм нахождения максимума в столбце матрицы

02.04.2012, 15:47. Показов 1786. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет отзывчивым, написал алгоритм нахождения максимума в столбце а он не роботает не пойму в чем проблема..
участок где сам код находится выделил "//////////////////////"


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
#include <iostream>
using namespace std;
void main()
{
    int i,j,n,m,k,d=0;
    cout<<"Vvedite razmeronst matrix: NxM\n"<<endl;
    cin>>n>>m;
    cout<<"\n Razmer matrix["<<n<<"]"<<"["<<m<<"]"<<endl;
    int **mas=new int *[n];
    for(i=0;i<n;i++)
    {
        mas[i]=new int [m];
    }
 
    for(i=0;i<n;++i)
    {
        for(j=0;j<m;++j)
        {
            cout<<(mas[i][j]=rand()%44-4)<<"\t";
        }
        cout<<"\n"<<endl;
    }
    cout<<" _____________________________"<<endl;
 
    int *max=new int[n];
    ////////////////////////////////////////////////
    for(i=0;i<m;++i)
    {
        max[i]=mas[i][0];
        for(j=0;j<n;++j)
        {
            if(max[i]<mas[j][i])
            {
                max[i]=mas[j][i];
            }
        }
    }
//////////////////////////////////////////////////
    for(int k=0;k<n;++k)
    {
        cout<<max[i]<<" ";
    }
    cout<<endl;
for(int k=0;k<n;++k)
    {
        delete[] mas[i];
    }
    delete[] mas;
    delete[] max;
 
    system("PAUSE");
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.04.2012, 15:47
Ответы с готовыми решениями:

Матрицы: нахождение минимума в каждом столбце и максимума в каждой строке
Добрый вечер. Помогите, пожалуйста, не могу объединить эти две программы нахождения минимального элемента в каждом столбце и максимального...

Функция нахождения максимума в строке матрицы и функция вычисления ||D||
Помогите написать программу. Заранее спасибо. Даны вещественные матрицы A, B, C размером 5x6. Вычислить величину ...

Макрос для нахождения максимального значения в каждом столбце данной матрицы
В таблице Excel в диапазон A1:Е5 внесите любые числа. Напишите макрос для нахождения максимального значения в каждом столбце данной...

9
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
02.04.2012, 15:51
30-ую строку проверьте, вероятно там должно быть [0][i].
1
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
02.04.2012, 15:54
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
#include <iostream>
using namespace std;
void main()
{
    int i,j,n,m,k,d=0;
    cout<<"Vvedite razmeronst matrix: NxM\n"<<endl;
    cin>>n>>m;
    cout<<"\n Razmer matrix["<<n<<"]"<<"["<<m<<"]"<<endl;
    int **mas=new int *[n];
    for(i=0;i<n;i++)
    {
        mas[i]=new int [m];
    }
 
    for(i=0;i<n;++i)
    {
        for(j=0;j<m;++j)
        {
            cout<<(mas[i][j]=rand()%44-4)<<"\t";
        }
        cout<<"\n"<<endl;
    }
    cout<<" _____________________________"<<endl;
 
    int *max=new int[m];
    ////////////////////////////////////////////////
    for(i=0;i<m;++i)
    {
        max[i]=mas[0][i];
        for(j=1;j<n;++j)
        {
            if(max[i]<mas[j][i])
            {
                max[i]=mas[j][i];
            }
        }
    }
//////////////////////////////////////////////////
    for(int k=0;k<m;++k)
    {
        cout<<max[k]<<" ";
    }
    cout<<endl;
for(int k=0;k<n;++k)
    {
        delete[] mas[k];
    }
    delete[] mas;
    delete[] max;
 
    system("PAUSE");
}
0
 Аватар для na3ar1y
48 / 4 / 3
Регистрация: 14.11.2010
Сообщений: 163
02.04.2012, 16:00  [ТС]
Цитата Сообщение от fasked Посмотреть сообщение
30-ую строку проверьте, вероятно там должно быть [0][i].
точно спс, но и еще проблема массив "мах" он не заполняется максимумами там пустой массив. что это может быть??

Добавлено через 3 минуты
Цитата Сообщение от valeriikozlov Посмотреть сообщение
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
#include <iostream>
using namespace std;
void main()
{
    int i,j,n,m,k,d=0;
    cout<<"Vvedite razmeronst matrix: NxM\n"<<endl;
    cin>>n>>m;
    cout<<"\n Razmer matrix["<<n<<"]"<<"["<<m<<"]"<<endl;
    int **mas=new int *[n];
    for(i=0;i<n;i++)
    {
        mas[i]=new int [m];
    }
 
    for(i=0;i<n;++i)
    {
        for(j=0;j<m;++j)
        {
            cout<<(mas[i][j]=rand()%44-4)<<"\t";
        }
        cout<<"\n"<<endl;
    }
    cout<<" _____________________________"<<endl;
 
    int *max=new int[m];
    ////////////////////////////////////////////////
    for(i=0;i<m;++i)
    {
        max[i]=mas[0][i];
        for(j=1;j<n;++j)
        {
            if(max[i]<mas[j][i])
            {
                max[i]=mas[j][i];
            }
        }
    }
//////////////////////////////////////////////////
    for(int k=0;k<m;++k)
    {
        cout<<max[k]<<" ";
    }
    cout<<endl;
for(int k=0;k<n;++k)
    {
        delete[] mas[k];
    }
    delete[] mas;
    delete[] max;
 
    system("PAUSE");
}
не пойму почему "j=1" в другом форе
0
347 / 292 / 37
Регистрация: 23.03.2012
Сообщений: 838
02.04.2012, 16:01
Цитата Сообщение от na3ar1y Посмотреть сообщение
точно спс, но и еще проблема массив "мах" он не заполняется максимумами там пустой массив. что это может быть??

Добавлено через 3 минуты

не пойму почему "j=1" в другом форе
в форах у тебя k, а внутри используется i.
2) ты присваиваешь изначально максимум 0-ой ячейке, поэтому цикл дальше уже прогоняешь с 1-ой.
1
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
02.04.2012, 16:04
Цитата Сообщение от na3ar1y Посмотреть сообщение
не пойму почему "j=1" в другом форе
а зачем число сравнивать само с собой? Если написать j=0, то лишнее сравнение чисел, которое на результат не повлияет.
1
 Аватар для na3ar1y
48 / 4 / 3
Регистрация: 14.11.2010
Сообщений: 163
02.04.2012, 16:06  [ТС]
Цитата Сообщение от Nekto Посмотреть сообщение
в форах у тебя k, а внутри используется i.
2) ты присваиваешь изначально максимум 0-ой ячейке, поэтому цикл дальше уже прогоняешь с 1-ой.
о работает,спасибо большое!
я думал что не важно какую переменную задавать чтоб работать с массивом, а получается что очень важно задавать одну и ту же переменную но почему разницы то нет? или есть но я ее не вижу. объясните пожалуйста буде очень благодарен)
0
347 / 292 / 37
Регистрация: 23.03.2012
Сообщений: 838
02.04.2012, 16:12
Цитата Сообщение от na3ar1y Посмотреть сообщение
о работает,спасибо большое!
я думал что не важно какую переменную задавать чтоб работать с массивом, а получается что очень важно задавать одну и ту же переменную но почему разницы то нет? или есть но я ее не вижу. объясните пожалуйста буде очень благодарен)
Всё равно какую переменную задаёшь. Просто если ты запускаешь for с переменной k, то используй внутри эту переменную.
1
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
02.04.2012, 16:13
Если так (см комментарии):
C++
1
2
3
4
5
6
7
8
9
10
11
    for(i=0;i<m;++i)
    {
        max[i]=mas[0][i];// считаем максимальным элементом в столбце i самый верхний
        for(j=1;j<n;++j)
        {
            if(max[i]<mas[j][i])// сравниваем со значением в max[i] все элементы столбца i , начиная от второго сверху (начиная от элемента с индексом 1)
            {
                max[i]=mas[j][i];
            }
        }
    }
А если так (см комментарии):
C++
1
2
3
4
5
6
7
8
9
10
11
    for(i=0;i<m;++i)
    {
        max[i]=mas[0][i];// считаем максимальным элементом в столбце i самый верхний
        for(j=0;j<n;++j)
        {
            if(max[i]<mas[j][i])// сравниваем со значением в max[i] все элементы столбца i , начиная от первого сверху (начиная от элемента с индексом 0). Т.е. записали в max[i] значение mas[0][i] и при j==0 сравниваем max[i] с mas[0][i]
            {
                max[i]=mas[j][i];
            }
        }
    }
1
 Аватар для na3ar1y
48 / 4 / 3
Регистрация: 14.11.2010
Сообщений: 163
02.04.2012, 16:23  [ТС]
Цитата Сообщение от valeriikozlov Посмотреть сообщение
Если так (см комментарии):
C++
1
2
3
4
5
6
7
8
9
10
11
    for(i=0;i<m;++i)
    {
        max[i]=mas[0][i];// считаем максимальным элементом в столбце i самый верхний
        for(j=1;j<n;++j)
        {
            if(max[i]<mas[j][i])// сравниваем со значением в max[i] все элементы столбца i , начиная от второго сверху (начиная от элемента с индексом 1)
            {
                max[i]=mas[j][i];
            }
        }
    }
А если так (см комментарии):
C++
1
2
3
4
5
6
7
8
9
10
11
    for(i=0;i<m;++i)
    {
        max[i]=mas[0][i];// считаем максимальным элементом в столбце i самый верхний
        for(j=0;j<n;++j)
        {
            if(max[i]<mas[j][i])// сравниваем со значением в max[i] все элементы столбца i , начиная от первого сверху (начиная от элемента с индексом 0). Т.е. записали в max[i] значение mas[0][i] и при j==0 сравниваем max[i] с mas[0][i]
            {
                max[i]=mas[j][i];
            }
        }
    }
Спасибо что ты так подробней расписал но это я понял после первого твоего ответа, я не понял то что у меня массив макс выдавал непонятные значения а проблема была в том что я глобальной переменной пользовался а надо было локально, Nekto мне объяснил хорошо)) спасиба ему и тебе тоже!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.04.2012, 16:23
Помогаю со студенческими работами здесь

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

Заменить на дополнение до максимума все элементы матрицы, расположенные правее максимума
паскалАВС:В массиве 6 на 7 целого типа в строках заменить на дополнение до максимума все элементы расположенные правее максимума. нельзя...

Составить функцию нахождения минимального элемента среди положительных элементов в столбце матрицы и его индек
вот условие: Составить функцию нахождения минимального элемента среди положительных элементов в столбце матрицы и его индексов (сам не...

Алгоритм нахождения обратной матрицы
Доброго вечера У кого-нибудь есть алгоритм нахождения обратной матрицы? Препод требует, и его не устраивает внутренняя функция A^-1 ...

Разработать программу для нахождения количества нулевых элементов матрицы, являющихся единственными в своей строке и столбце
Очень нужна Ваша помощь. Сама в этом почти ничего не понимаю, а зачет по этим задачам уже в эту пятницу. Я очень сильно надеюсь на Вашу...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru