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

В матрице найти максимальный и минимальный элемент,переставить строки в которых они находится

28.01.2014, 11:53. Показов 1219. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте уважаемые форумчане. Я столкнулся с проблемой вот такой: Разработайте программу обработки массивов. Входные данные введите с клавиатуры. Результаты работы программы отобразите на экране.
Я только учусь так что еще пока все плохо. Матрица размером N*N Не могу понять как в матрице найти максимальный и минимальный элемент,переставить строки в которых они находится и если они в одной строке выдать об этом сообщение.
Вот код который пытаюсь за шаманить оО
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
#include <iostream>
#include <iomanip>
 
 template <class T>
T MOD(T a)
{
  return ( (a) < 0? -(a) : (a) );
}
 
void input_matrix(int **matrix, const size_t matrix_size){
  for(int i = 0; i < matrix_size; ++i)
    for(int j = 0; j < matrix_size; ++j){
      std::cout << "\nMtarix[" << i << "][" << j << "] = ";
      std::cin >> matrix[i][j];
    }
}
 
void output_matrix(int **matrix, const size_t matrix_size){
  for(int i = 0; i < matrix_size; ++i){
    for(int j = 0; j < matrix_size; ++j)
      std::cout << std::setw(3) << matrix[i][j] << ' ';
  }
  std::cout << '\n';
}
 
bool cheking(int **matrix, const size_t matrix_size){
  bool ort = true;
  int pr = 0;
  for (int i = 0; i < matrix_size - 1 && ort; ++i){
    pr = 0;
    for (int k = i + 1; k < matrix_size && ort; ++k)
      for(int j = 0; j < matrix_size; ++j)
        pr += matrix[i][j] * matrix[k][j];
    if (MOD(pr) > 0.0001)
      ort = false;
  }
  for (int i = 0; i < matrix_size - 1 && ort; ++i){
    pr = 0;
    for(int j = 0; j < matrix_size; ++j)
      pr += matrix[i][j] * matrix[i][j];
    if (MOD(pr - 1) > 0.0001)
      ort = false;
  }
  return ort;
}
 
int main() {
  size_t matrix_size;
  std::cout << "\n\nInput matrix size -> ";
  std::cin >> matrix_size;
  int **matrix = new int*[matrix_size];
  for(int i = 0; i < matrix_size; ++i)
    matrix[i] = new int[matrix_size];
  input_matrix(matrix, matrix_size);
  std::cout << '\n';
  output_matrix(matrix, matrix_size);
  std::cout << ( cheking(matrix, matrix_size)? "YES" : "NO" ) << std::endl;
  for(int i = 0; i < matrix_size; ++i)
    delete[] matrix[i];
  delete[] matrix;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.01.2014, 11:53
Ответы с готовыми решениями:

Матрица. Найти максимальный и минимальный элементы. Переставить строки, в которых они находятся
Дана вещественная квадратная матрица. Найти максимальный и минимальный элементы. Переставить строки, в которых они находятся. Если они...

Массивы. Найти в матрице максимальный и минимальный элементы, поменять местами строки, в которых они расположены
Операции с двумерными массивами Найти в матрице максимальный и минимальный элементы, поменять местами строки, в которых они расположены.

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

3
 Аватар для gigder
3 / 3 / 1
Регистрация: 28.09.2012
Сообщений: 33
28.01.2014, 13:55
Не знаю, что ты шаманишь. Я делал так:
C++
1
2
3
4
5
6
7
max=matrix[0][0]
for(i=0;i<n;i++)
{
      for(j=0;j<n;j++)
         if (matrix[i][j]>max)
            max=matrix[i][j];
}
С мин.анологично. Ну, если я правильно тебя понял, то должно подойти
1
 Аватар для cooller
571 / 539 / 280
Регистрация: 25.12.2013
Сообщений: 1,456
28.01.2014, 14:22
razqr,
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
#include<iostream>
#include<cstdlib>
#include<ctime>
#include<iomanip>
int main()
{
    size_t arraySize;
    std::cin>>arraySize;
    srand(time(NULL));
    int **array = new int *[arraySize];
    for(size_t i=0; i<arraySize; i++)
        array[i] = new int [arraySize];
    std::cout<<"\nMatrix:\n";
    for(size_t i=0; i<arraySize; i++,std::cout<<std::endl)
        for(size_t j=0; j<arraySize; j++)
            std::cout<<std::setw(5)<<(array[i][j] = rand()%20 - 5);
    int Max = array[0][0],Min = array[0][0];
    size_t RowMax(0),RowMin(0);
    for(size_t i=0; i<arraySize; i++)
        for(size_t j=0; j<arraySize; j++)
        {
            if(Max<array[i][j])
            {
                Max = array[i][j];
                RowMax = i;
            }
            if(Min>array[i][j])
            {
                Min = array[i][j];
                RowMin = i;
            }
        }
    if(RowMax==RowMin)
        std::cout<<"\nMaximum and minimum element are in the same line";
    else
        for(size_t j=0; j<arraySize; j++)
            std::swap(array[RowMax][j],array[RowMin][j]);
    std::cout<<"\nNew matrix:\n";
    for(size_t i=0; i<arraySize; i++,std::cout<<std::endl)
        for(size_t j=0; j<arraySize; j++)
            std::cout<<std::setw(5)<<array[i][j];
    std::cout<<"\nMaximal element: "<<Max<<std::endl;
    std::cout<<"Minimal element: "<<Min;
}
0
28.01.2014, 14:51

Не по теме:

Цитата Сообщение от cooller_94 Посмотреть сообщение
for(size_t i=0; i<arraySize; i++,std::cout<<std::endl)
не лучший подход пихать код лишь бы уместить в одну строку.

1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.01.2014, 14:51
Помогаю со студенческими работами здесь

Нужно найти минимальный и максимальный элемент массива и поменять местами строчки, в которых они находятся
Друзья помогите исправить код, нужно найти мин и макс элемент массива и поменять строчки в которых они находятся местами. ввод вывод верный...

Найти максимальный и минимальный элементы и поменять местами строки, в которых они находятся (комментарий)
Посчитать произведение всех отрицательных элементов матрицы. Найти максимальный и минимальный элементы и поменять местами строки, в...

Заменить максимальный элемент в матрице, средним арифметическим элементов строки, в которой находится максимальный элемент
Уважаемые форумчане! Помогите с задачкой :) (С++) В матрице D максимальный элемент заменить средним арифметическим элементов строки,...

Найти номер строки и столбца на пересечении которых находится минимальный элемент матрицы
1) Составить программу, которая вычисляет количество и сумму элементов, кратных 5 для введенного с клавиатуры одномерного массива целых...

Найти номер строки и столбца на пересечении которых находится минимальный элемент матрицы
Дана матрица целых чисел размерностью m x n. Найти номер строки и столбца на пересечении которых находится минимальный элемент матрицы.


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru