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

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

02.04.2012, 15:47. Показов 1747. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru