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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
xGravity
0 / 0 / 0
Регистрация: 03.01.2010
Сообщений: 42
#1

матрицы - C++

03.01.2010, 12:56. Просмотров 485. Ответов 7
Метки нет (Все метки)

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

Матрицы. Найти и распечатать сумму элементов 5-го столбца матрицы А и сумму элементов последней строки матрицы В - C++
Даны две матрицы А(mxn)и В(m1xn1).программа находит и распечатывает сумму элементов 5-го столбца матрицы А и сумму элементов последней...

Матрицы. Программа, которая удаляет столбец матрицы, содержащий максимальный ее элемент - C++
Я новичок в с++...поэтому оооочень нужна Ваша помощь!!! Необходимо написать программу, которая удаляет столбец матрицы, содержащий...

Зеркально отразить элементы матрицы относительно горизонтальной оси симметрии матрицы - C++
Здравствуйте! Помогите написать 3 программмы на C++ на задачи с двумерными массивами 3. Дана матрица размера M x N. Зеркально...

Вычесть из элементов первого столбца матрицы значение максимального элемента матрицы - C++
Составить программу, в которой 1) организовать ввод матрицы размера mxn из целых чисел; 2) вычесть из элементов первого столбца матрицы...

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

Найти количество элементов матрицы, которые совпадают с элементами другой матрицы - C++
Помогите найти количество элементов 2 мерного массива, которые совпадают с элементами другого аналогичного массива. Массив 5х3.

7
Vladimir_Limaki
1 / 1 / 0
Регистрация: 02.01.2010
Сообщений: 39
03.01.2010, 15:04 #2
Цитата Сообщение от xGravity Посмотреть сообщение
Помогите плиз новичку решить задачу с матрицой.
Вот собственно условие:
В действительной матрице размера n x m (n, m <10) упорядочить строки по убыванию среднего значения их элементов. Размер матрицы и ее элементы вводятся с клавиатуры. Оформить ввод и вывод матрицы.Исходный код нужен на С++.
как понять упорядочить строки по убыванию среднего значения их элементов.
0
valeriikozlov
Эксперт С++
4670 / 2496 / 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; 
}
1
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)
0
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
03.01.2010, 15:21 #5
xGravity, Vladimir_Limaki, В данном случае можно просто по сумме элементов в строках, ведь кол-во элементов в каждой строке одинаковое.
0
xGravity
0 / 0 / 0
Регистрация: 03.01.2010
Сообщений: 42
03.01.2010, 15:37  [ТС] #6
Да ты прав можно и просто по сумме сортировать результат всеравно будет тот же

Добавлено через 11 минут
спс valeriikozlov.Обьясни ток плиз што значит обьявление **mas в 6 строке.И еще 12 16 строки
0
valeriikozlov
Эксперт С++
4670 / 2496 / 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.
0
xGravity
0 / 0 / 0
Регистрация: 03.01.2010
Сообщений: 42
03.01.2010, 16:46  [ТС] #8
спс за помощь
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.01.2010, 16:46
Привет! Вот еще темы с ответами:

Алгоритм обработки матрицы: Нахождение максимального элемента матрицы и его номера. - C++
Алгоритм обработки матрицы: Нахождение максимального элемента матрицы и его номера.

Сформировать одномерный массив из диагональных элементов матрицы. Найти след матрицы - C++
Для заданной квадратной матрицы сформировать одномерный массив из ее диагональных элементов. Найти след матрицы, суммируя элементы...

Для матрицы найти такие k, что k-я строка матрицы совпадает с k-м столбцом - C++
Помогите пожалуйста с первой частью задания: найти такие k. что k -строка матрицы совпадает с k-м столбцом. При компиляции выдается...

Для матрицы найти такие k, что k-я строка матрицы совпадает с k-м столбцом - C++
Помогите решить задачку Для заданной матрицы размером 8 на 8 найти такие k, что k-я строка матрицы совпадает с k-м столбцом. Найти...


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

Или воспользуйтесь поиском по форуму:
8
Yandex
Объявления
03.01.2010, 16:46
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru