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

матрицы - C++

Восстановить пароль Регистрация
 
xGravity
0 / 0 / 0
Регистрация: 03.01.2010
Сообщений: 42
03.01.2010, 12:56     матрицы #1
Помогите плиз новичку решить задачу с матрицой.
Вот собственно условие:
В действительной матрице размера n x m (n, m <10) упорядочить строки по убыванию среднего значения их элементов. Размер матрицы и ее элементы вводятся с клавиатуры. Оформить ввод и вывод матрицы.Исходный код нужен на С++.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.01.2010, 12:56     матрицы
Посмотрите здесь:

Алгоритм обработки матрицы: Нахождение максимального элемента матрицы и его номера. C++
Зеркально отразить элементы матрицы относительно горизонтальной оси симметрии матрицы C++
Матрицы. Найти и распечатать сумму элементов 5-го столбца матрицы А и сумму элементов последней строки матрицы В C++
Матрицы. Программа, которая удаляет столбец матрицы, содержащий максимальный ее элемент C++
Поменять большие элементы в строке матрицы с маленькими элементами этой же матрицы C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Vladimir_Limaki
1 / 1 / 0
Регистрация: 02.01.2010
Сообщений: 39
03.01.2010, 15:04     матрицы #2
Цитата Сообщение от xGravity Посмотреть сообщение
Помогите плиз новичку решить задачу с матрицой.
Вот собственно условие:
В действительной матрице размера n x m (n, m <10) упорядочить строки по убыванию среднего значения их элементов. Размер матрицы и ее элементы вводятся с клавиатуры. Оформить ввод и вывод матрицы.Исходный код нужен на С++.
как понять упорядочить строки по убыванию среднего значения их элементов.
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
03.01.2010, 15:11     матрицы #3
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
#include<iostream>
#include<windows.h>
using namespace std;
int main ()
{
    double **mas,temp1, temp2;
    int n, m, i,j,j1;
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    cout<<"Введите количество строк матрицы: "<< endl;
    cin>>n;
    mas=new double*[n];
    cout<<"Введите количество столбцов матрицы: "<< endl;
    cin>>m;
    for(i=0; i<n; i++)
       mas[i]=new double[m];
    cout<<"Введите элементы матрицы: "<< endl;
    for(i=0; i<n; i++)
       for(j=0; j<m; j++)
       {
          cout<<"["<<i<<"]["<<j<<"]= ";
          cin>>mas[i][j];
       }
        cout<<"исходная матрица"<<endl;
    for(i=0; i<n; i++)
        {
       for(j=0; j<m; j++)
       {
           cout.width(5);
          cout<<mas[i][j]<<" ";
       }
          cout<<endl;
        }
    for(i=0; i<n; i++)
        for(j=0; j<n-1-i; j++)
        {
            temp1=temp2=0;
            for(j1=0; j1<m; j1++)
            {
            temp1+=mas[j][j1];
            temp2+=mas[j+1][j1];
            }
            if(temp1<temp2)
                for(j1=0; j1<m; j1++)
                {
                    temp1=mas[j][j1];
                    mas[j][j1]=mas[j+1][j1];
                    mas[j+1][j1]=temp1;
                }
        }
    cout<<"отсортированная матрица"<<endl;
    for(i=0; i<n; i++)
        {
       for(j=0; j<m; j++)
       {
           cout.width(5);
          cout<<mas[i][j]<<" ";
       }
          cout<<endl;
         }
    system("pause");
     
    return 0; 
}
xGravity
0 / 0 / 0
Регистрация: 03.01.2010
Сообщений: 42
03.01.2010, 15:18  [ТС]     матрицы #4
Цитата Сообщение от Vladimir_Limaki Посмотреть сообщение
как понять упорядочить строки по убыванию среднего значения их элементов.
Например исходная матрица
5 9 8 (ср. арифмет.=7,33)
4 2 6 (ср арифмет.=4)
7 4 5 (ср арифмет.=5,33)

Отсортированная
5 9 8 (ср. арифмет.=7,33)
7 4 5 (ср арифмет.=5,33)
4 2 6 (ср арифмет.=4)
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
03.01.2010, 15:21     матрицы #5
xGravity, Vladimir_Limaki, В данном случае можно просто по сумме элементов в строках, ведь кол-во элементов в каждой строке одинаковое.
xGravity
0 / 0 / 0
Регистрация: 03.01.2010
Сообщений: 42
03.01.2010, 15:37  [ТС]     матрицы #6
Да ты прав можно и просто по сумме сортировать результат всеравно будет тот же

Добавлено через 11 минут
спс valeriikozlov.Обьясни ток плиз што значит обьявление **mas в 6 строке.И еще 12 16 строки
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
03.01.2010, 16:01     матрицы #7
Цитата Сообщение от xGravity Посмотреть сообщение
**mas
Полностью:
C++
1
double **mas;
- объявляется переменная указатель на массив указателей, каждый из указателей которого указывает на массив элементов типа double.
C++
1
  mas=new double*[n];
Здесь мы выделяем динамически память для массива размером n, элементами которого являются указатели на массивы с элементами типа double. И после выделения этой памяти, адрес ее присваиваем переменной mas.
C++
1
mas[i]=new double[m];
- Выделяем память под массив размером m, элементы которого имеют тип double, затем адрес этой памяти присваиваем указателям из массива, о котором писал строкой выше.
Все строчки о которых спрашиваете, как раз создают динамически двумерный массив размером n*m.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.01.2010, 16:46     матрицы
Еще ссылки по теме:

C++ Вычесть из элементов первого столбца матрицы значение максимального элемента матрицы
C++ Найти количество элементов матрицы, которые совпадают с элементами другой матрицы
C++ Преобразование матрицы (удалить из матрицы столбец с наибольшей по модулю суммой элементов)

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

Или воспользуйтесь поиском по форуму:
xGravity
0 / 0 / 0
Регистрация: 03.01.2010
Сообщений: 42
03.01.2010, 16:46  [ТС]     матрицы #8
спс за помощь
Yandex
Объявления
03.01.2010, 16:46     матрицы
Ответ Создать тему
Опции темы

Текущее время: 20:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru