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

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

Войти
Регистрация
Восстановить пароль
 
 
V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,685
#1

сортировка матрицы - C++

07.10.2011, 01:03. Просмотров 759. Ответов 16
Метки нет (Все метки)

В матрице 5*10 упорядочить элементы в каждой строке по убыванию, а строки матрицы
Расположить по возратанию элементов
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.10.2011, 01:03
Здравствуйте! Я подобрал для вас темы с ответами на вопрос сортировка матрицы (C++):

сортировка матрицы - C++
Доброго времени суток. Задание: поменять в каждой строке максимальный и минимальный элементы на 0. Я думаю ошибка в функции void...

Сортировка матрицы - C++
Дана:матрица чисел размером m x n, m – число строк, n – число столбцов.Выполнить сортировку (в порядке возрастания) по строкам всех...

Сортировка матрицы - C++
Здравствуйте, я уже голову сломал, но как сделать перестановку строк по убыванию значений максимальных элементов строк. Т.е. дана матрица...

Сортировка матрицы - C++
Всем привет! Прошу помощи в решении вот такой задачи: Дана матрица (N+15)x(N+15) отсортировать главную диагональ, числа генерировать...

Сортировка матрицы - C++
Нужно написать программу, которая проводит сортировку элементов матрицы b Помогите

Сортировка матрицы - C++
все нулевые элементы размещены в левой части матрицы

16
castaway
Эксперт С++
4885 / 3020 / 370
Регистрация: 10.11.2010
Сообщений: 11,078
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:13 #2
Надо перебрать в каждой строке элементы, и расположиться их так, пока они не будут располагаться в порядке убывания, и так же поступить со строками, но только по возрастанию.
0
V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,685
07.10.2011, 01:14  [ТС] #3
извините не коректоно написал, надо упорядочить элементы в каждой строке по убыванию а строки расположить по возрастанию суммы элементов . вывести массив и сумму элеметов строки возле самой строки
0
castaway
Эксперт С++
4885 / 3020 / 370
Регистрация: 10.11.2010
Сообщений: 11,078
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:34 #4
Вадик, а откуда у тебя репутация в 40 баллов!???
0
V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,685
07.10.2011, 01:35  [ТС] #5
я на паскале писал а щас на Си перехожу и сложновато пока
0
easybudda
Модератор
Эксперт CЭксперт С++
9681 / 5631 / 954
Регистрация: 25.07.2009
Сообщений: 10,808
07.10.2011, 01:37 #6
грязный хак
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
#define ROWS 5
#define COLUMNS 10
 
int asc_cmp(const void * a, const void * b){
    return *(int*)a - *(int*)b;
}
 
int desc_cmp(const void * a, const void * b){
    return *(int*)b - *(int*)a;
}
 
int main(void){
    int arr[ROWS][COLUMNS], i, j;
 
    srand(time(NULL));
 
    for ( i = 0; i < ROWS; ++i )
        for ( j = 0; j < COLUMNS; ++j )
            arr[i][j] = rand() % 100;
 
    printf("Unsorted:\n");
    for ( i = 0; i < ROWS; ++i )
        for ( j = 0; j < COLUMNS; ++j )
            printf("%02d%c", arr[i][j], ( j < COLUMNS - 1 ) ? ' ' : '\n');
 
    qsort((int*)arr, ROWS * COLUMNS, sizeof(int), asc_cmp);
    for ( i = 0; i < ROWS; ++i )
        qsort( arr[i], COLUMNS, sizeof(int), desc_cmp);
 
    printf("Sorted:\n");
    for ( i = 0; i < ROWS; ++i )
        for ( j = 0; j < COLUMNS; ++j )
            printf("%02d%c", arr[i][j], ( j < COLUMNS - 1 ) ? ' ' : '\n');
 
    return 0;
}
http://codepad.org/ZtbF63Rw
1
V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,685
07.10.2011, 01:41  [ТС] #7
Цитата Сообщение от easybudda Посмотреть сообщение
грязный хак
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
#define ROWS 5
#define COLUMNS 10
 
int asc_cmp(const void * a, const void * b){
    return *(int*)a - *(int*)b;
}
 
int desc_cmp(const void * a, const void * b){
    return *(int*)b - *(int*)a;
}
 
int main(void){
    int arr[ROWS][COLUMNS], i, j;
 
    srand(time(NULL));
 
    for ( i = 0; i < ROWS; ++i )
        for ( j = 0; j < COLUMNS; ++j )
            arr[i][j] = rand() % 100;
 
    printf("Unsorted:\n");
    for ( i = 0; i < ROWS; ++i )
        for ( j = 0; j < COLUMNS; ++j )
            printf("%02d%c", arr[i][j], ( j < COLUMNS - 1 ) ? ' ' : '\n');
 
    qsort((int*)arr, ROWS * COLUMNS, sizeof(int), asc_cmp);
    for ( i = 0; i < ROWS; ++i )
        qsort( arr[i], COLUMNS, sizeof(int), desc_cmp);
 
    printf("Sorted:\n");
    for ( i = 0; i < ROWS; ++i )
        for ( j = 0; j < COLUMNS; ++j )
            printf("%02d%c", arr[i][j], ( j < COLUMNS - 1 ) ? ' ' : '\n');
 
    return 0;
}
http://codepad.org/ZtbF63Rw
впрочем программа работает совсем некоректно
0
castaway
Эксперт С++
4885 / 3020 / 370
Регистрация: 10.11.2010
Сообщений: 11,078
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:41 #8
Ну давай я тебе немного помогу, а то уже засыпаю...
Я так понимаю ее надо сначала чем-то заполнить:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <stdio.h>
#include <stdlib.h>
 
int main()
{
    int m[5][10], i, j;
 
    // заполняем матрицу
    for ( i = 0; i < 5; i++ ) {
        for ( j = 0; j < 10; j++ ) {
            m[i][j] = rand() % 100;
        }
    }
 
 
    // ...
 
    return 0;
}
1
V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,685
07.10.2011, 01:42  [ТС] #9
спасибо и на этом но каким бы галимым програмером я бы не был рандом я напишу даже в СИ)))
0
castaway
Эксперт С++
4885 / 3020 / 370
Регистрация: 10.11.2010
Сообщений: 11,078
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:42 #10
easybudda, эээ ты спер у меня код rand() % 100 !!!
0
V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,685
07.10.2011, 01:44  [ТС] #11
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <stdlib.h>//srand
#include <stdio.h> //printf
#include <conio.h> //getch
#include <time.h>  //time
 
int main()
{
        int i,j,arr[5][10];
        srand(time(0));//for rand
        printf("Enter array\r\n");
        for(i = 0; i < 5; i++)
        {
                for(j = 0; j < 10; j++)
                {
                        arr[i][j] = rand()%100;//from 0 to 100
                        printf("%d ",arr[i][j]);
                }
                printf("\r\n");
        }
мой рандом
0
castaway
Эксперт С++
4885 / 3020 / 370
Регистрация: 10.11.2010
Сообщений: 11,078
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:47 #12
Цитата Сообщение от V@D!k Посмотреть сообщение
//from 0 to 100
* от 0 до 99 включительно! (чтобы не возникло заблуждений)
0
easybudda
Модератор
Эксперт CЭксперт С++
9681 / 5631 / 954
Регистрация: 25.07.2009
Сообщений: 10,808
07.10.2011, 01:47 #13
Цитата Сообщение от V@D!k Посмотреть сообщение
впрочем программа работает совсем некоректно
Программа работает в точности так, как сначала в задании написал. Кто же виноват, что задание не корректное?
Переделывать не буду, подскажу возможный вариант: сделать в матрице на 1 столбец больше и складывать в него сумму остальных столбцов, а потом сортировать строки по значению этого столбца.
1
V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,685
07.10.2011, 01:49  [ТС] #14
хм, я про такой вариант не думал, я думал просто считать сумму сранивать и выводить по строке
0
sandye51
программист С++
685 / 587 / 39
Регистрация: 19.12.2010
Сообщений: 2,016
07.10.2011, 02:08 #15
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
#include <iostream>
#include <vector>
#include <cstdlib>
#include <ctime>
#include <algorithm>
#include <iterator>
 
#define n 5
#define m 10
#define MAX_VALUE 100
 
int main()
{
   srand(static_cast<unsigned int>(time(NULL)));
   
   std::vector<std::vector<double> > matrix(m, std::vector<double>(n));
   
   std::cout << "Enter the matrix's values" << std::endl;
   for (auto i = matrix.begin(), end = matrix.end(); i != end; ++i)
   {
      for (auto j = i->begin(), end = i->end(); j != end; ++j)
         *j = rand() % MAX_VALUE;
         
      std::sort(i->begin(), i->end(), std::less<double>());
   }
 
   std::sort(matrix.begin(), matrix.end(), [](const std::vector<double>& v1,
   const std::vector<double>& v2)->bool { return v1.front() < v2.front(); });
   
   std::for_each(matrix.begin(), matrix.end(), [](const std::vector<double>& v)->void
   { std::copy(v.begin(), v.end(), std::ostream_iterator<double>(std::cout, " ")); std::cout << std::endl; });
   
   return EXIT_SUCCESS;
}
1
07.10.2011, 02:08
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.10.2011, 02:08
Привет! Вот еще темы с ответами:

Сортировка матрицы. - C++
Имеется матрица.Переставить столбцы матрицы в порядке убывания сумм элементов. SOS

Сортировка матрицы - C++
Как преобразовать код чтобы матрица сортировалась снизу-вверх-вправо с конца главной диагонали? void matrixToArr(int matr,int nRow,...

Сортировка матрицы - C++
Элементы главной диагонали квадратной матрицы расположить в порядке убывания.

Сортировка матрицы - C++
Товарищи, подскажите пожалуйста, как можно решить это задание? (8 б.) В начале каждой строки частично заполненной матрицы А(m,n)...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Опции темы

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