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

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

Восстановить пароль Регистрация
 
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
07.10.2011, 01:03     сортировка матрицы #1
В матрице 5*10 упорядочить элементы в каждой строке по убыванию, а строки матрицы
Расположить по возратанию элементов
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.10.2011, 01:03     сортировка матрицы
Посмотрите здесь:

C++ Сортировка матрицы С++
Сортировка матрицы C++
Сортировка матрицы C++
Сортировка матрицы C++
C++ Сортировка матрицы
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
castaway
Эксперт С++
4837 / 2976 / 367
Регистрация: 10.11.2010
Сообщений: 11,008
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:13     сортировка матрицы #2
Надо перебрать в каждой строке элементы, и расположиться их так, пока они не будут располагаться в порядке убывания, и так же поступить со строками, но только по возрастанию.
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
07.10.2011, 01:14  [ТС]     сортировка матрицы #3
извините не коректоно написал, надо упорядочить элементы в каждой строке по убыванию а строки расположить по возрастанию суммы элементов . вывести массив и сумму элеметов строки возле самой строки
castaway
Эксперт С++
4837 / 2976 / 367
Регистрация: 10.11.2010
Сообщений: 11,008
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:34     сортировка матрицы #4
Вадик, а откуда у тебя репутация в 40 баллов!???
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
07.10.2011, 01:35  [ТС]     сортировка матрицы #5
я на паскале писал а щас на Си перехожу и сложновато пока
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
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
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
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
впрочем программа работает совсем некоректно
castaway
Эксперт С++
4837 / 2976 / 367
Регистрация: 10.11.2010
Сообщений: 11,008
Записей в блоге: 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;
}
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
07.10.2011, 01:42  [ТС]     сортировка матрицы #9
спасибо и на этом но каким бы галимым програмером я бы не был рандом я напишу даже в СИ)))
castaway
Эксперт С++
4837 / 2976 / 367
Регистрация: 10.11.2010
Сообщений: 11,008
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:42     сортировка матрицы #10
easybudda, эээ ты спер у меня код rand() % 100 !!!
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
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");
        }
мой рандом
castaway
Эксперт С++
4837 / 2976 / 367
Регистрация: 10.11.2010
Сообщений: 11,008
Записей в блоге: 10
Завершенные тесты: 1
07.10.2011, 01:47     сортировка матрицы #12
Цитата Сообщение от V@D!k Посмотреть сообщение
//from 0 to 100
* от 0 до 99 включительно! (чтобы не возникло заблуждений)
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
07.10.2011, 01:47     сортировка матрицы #13
Цитата Сообщение от V@D!k Посмотреть сообщение
впрочем программа работает совсем некоректно
Программа работает в точности так, как сначала в задании написал. Кто же виноват, что задание не корректное?
Переделывать не буду, подскажу возможный вариант: сделать в матрице на 1 столбец больше и складывать в него сумму остальных столбцов, а потом сортировать строки по значению этого столбца.
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
07.10.2011, 01:49  [ТС]     сортировка матрицы #14
хм, я про такой вариант не думал, я думал просто считать сумму сранивать и выводить по строке
sandye51
программист С++
 Аватар для sandye51
677 / 579 / 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;
}
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
07.10.2011, 02:10  [ТС]     сортировка матрицы #16
спасибо большое но мне гадо в си
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.10.2011, 19:11     сортировка матрицы
Еще ссылки по теме:

C++ Сортировка матрицы 5*5
C++ Сортировка матрицы
Сортировка матрицы C++

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

Или воспользуйтесь поиском по форуму:
V@D!k
 Аватар для V@D!k
249 / 249 / 70
Регистрация: 26.07.2010
Сообщений: 1,684
10.10.2011, 19:11  [ТС]     сортировка матрицы #17
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
#include <stdio.h>
#include <stdlib.h>
 
 main()
{
    int mat[5][10],mas[6],i,j,k,max,m,maxst;
    srand(time(NULL));
    for (i=0;i<=5;i++)
    {
        for (j=0;j<=10;j++) 
        {
            mat[i][j]=rand()%100;
        }
    }
    printf(" Pervona4alnaya Matrica  \n \n");
    
    for (i=0;i<=5;i++)
    {
        for (j=0;j<=10;j++) printf(" %d ",mat[i][j]);
        printf(" \n");
    }
    for (i=0;i<=5;i++) mas[i]=0;
    for (i=0;i<=10;i++)
    {
        for (j=0;j<=5;j++)
        {
             mas[i]+=mat[i][j];
        }
    }
    printf("\n");
    for (i=0;i<=5;i++) 
    {
       printf("Summa %d-oi stroki ravna %d ",i+1,mas[i]);
       printf("\n");
    }
 
        max=0;      
    for (k=0;k<=5;k++)
    {
        for (i=0;i<=5;i++)
        {
          if ((mas[i]>max))        
            {                        
                max=mas[i];
                m=i;
            }
          }
           for (j=0;j<=10;j++) 
            printf(" %d ", mat[m][j]);
            printf("\n");
          maxst=max;
          max=0;
          mas[m]=0;
}
        getch(); 
}
исправьте плиз
Yandex
Объявления
10.10.2011, 19:11     сортировка матрицы
Ответ Создать тему
Опции темы

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