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

Сортировка диагоналей двумерного массива - C++

Восстановить пароль Регистрация
 
alex932109
0 / 0 / 0
Регистрация: 05.04.2012
Сообщений: 11
26.04.2012, 20:22     Сортировка диагоналей двумерного массива #1
Здравствуйте. Помогите решить вот такую задачу:
Дан целочисленный массив a(n,m). Упорядочить по неубыванию
элементы на главной диагонали и диагоналях, параллельных ей.
Перестановка элементов допускается только в пределах
соответствующей диагонали.
Заранее спасибо.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
26.04.2012, 21:24     Сортировка диагоналей двумерного массива #2
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
#include <cstdio>
#include <cstdlib>
#include <ctime>
#include <iostream>
using namespace std;
#define N_max 100
int main()
{
    srand( time( NULL ) );
    int n, m, a[N_max][N_max],i,j,y,t,t1;
    cout<<"n= "; cin>>n;
    cout<<"m= "; cin>>m;
    cout<<"Ishodn matr:"<<endl;
    for(i=0; i<n; i++)
    {
        for(j=0; j<m; j++)
        {
            a[i][j]=rand()%10;
            cout.width(4); cout<<a[i][j];
        }
        cout<<endl;
    }
    for(i=0; i<n; i++)
        for(j=0; i+j<n && j<m; j++)
        {
            t=j;
            for(y=j+1; i+y<n && y<m; y++)
                if(a[i+t][t]>a[i+y][y])
                    t=y;
            t1=a[i+j][j]; a[i+j][j]=a[i+t][t]; a[i+t][t]=t1;
        }
    for(i=1; i<m; i++)
        for(j=0; j<n && j+i<m; j++)
        {
            t=j;
            for(y=j+1; y<n && y+i<m; y++)
                if(a[t][i+t]>a[y][i+y])
                    t=y;
            t1=a[j][j+i]; a[j][j+i]=a[t][i+t]; a[t][i+t]=t1;
        }
    cout<<"Poluch matr:"<<endl;
    for(i=0; i<n; i++)
    {
        for(j=0; j<m; j++)
        {
            cout.width(4); cout<<a[i][j];
        }
        cout<<endl;
    }
 
   
    return 0;
}
alex932109
0 / 0 / 0
Регистрация: 05.04.2012
Сообщений: 11
26.04.2012, 21:33  [ТС]     Сортировка диагоналей двумерного массива #3
Спасибо большое. Не подскажите, что это srand( time( NULL ) ); за строка и что за библиотека сtime? Я так понимаю это чтоб получить рандомные неповторяющееся числа?
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
26.04.2012, 21:52     Сортировка диагоналей двумерного массива #4
Цитата Сообщение от alex932109 Посмотреть сообщение
Я так понимаю это чтоб получить рандомные неповторяющееся числа?
да, все правильно
alex932109
0 / 0 / 0
Регистрация: 05.04.2012
Сообщений: 11
27.04.2012, 10:13  [ТС]     Сортировка диагоналей двумерного массива #5
Подскажите пожалуйста, зачем нужна переменная t и зачем она приравнивается к j
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
28.04.2012, 07:32     Сортировка диагоналей двумерного массива #6
Цитата Сообщение от alex932109 Посмотреть сообщение
Подскажите пожалуйста, зачем нужна переменная t и зачем она приравнивается к j
Представьте себе очередную сортируемую диагональ в виде одномерного массива.
Идем по массиву с помощью переменной j:
Цитата Сообщение от valeriikozlov Посмотреть сообщение
for(j=0; j<n && j+i<m; j++)
Для каждого элемента с индексом j делаем следующее:
- сначало считаем что элемент с индексом j самый минимальный из всех элементов от него и до конца строки. Для этого и приравниваем t к j. Затем перебираем элементы до конца строки:
Цитата Сообщение от valeriikozlov Посмотреть сообщение
for(y=j+1; y<n && y+i<m; y++)
и если вдруг встречаем меньший элемент, на который показывает y , то t делаем равным y:
Цитата Сообщение от valeriikozlov Посмотреть сообщение
if(a[t][i+t]>a[y][i+y])
t=y;
в конце прохода t будет показывать на самый минимальный элемент от j до конца строки (включительно). Поэтому просто меняем местами элемент на который указывает j с элементом на который указывает t:
Цитата Сообщение от valeriikozlov Посмотреть сообщение
t1=a[j][j+i]; a[j][j+i]=a[t][i+t]; a[t][i+t]=t1;
В общем здесь реализована сортировка выбором.
Yandex
Объявления
28.04.2012, 07:32     Сортировка диагоналей двумерного массива
Ответ Создать тему
Опции темы

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