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

Метод попарно-обменной перестановки - C++

Восстановить пароль Регистрация
 
frank_lampard
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
25.10.2012, 19:15     Метод попарно-обменной перестановки #1
Условия программы: Упорядочить массив М (50) в порядке убывания методом попрано-обменной перестановки.

Добавлено через 2 часа 3 минуты
Как сделать такую программу?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
zitxbit
Master C/C++
 Аватар для zitxbit
86 / 738 / 75
Регистрация: 11.04.2012
Сообщений: 971
25.10.2012, 21:06     Метод попарно-обменной перестановки #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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
 
#define N 50
 
bool issorted(int* A, int n)
{
    for (int i = 0; i < n-1; i++)
        if (A[i] > A[i+1]) return false;
    return true;
}
 
void swap(int& n1, int& n2)
 { int _tn = n1; n1 = n2; n2 = _tn; }
 
int main()
{
    int* A = new int[N];
    for (int i = 0; i < N; i++)
    {
        A[i] = rand() % N + 1;
        printf("%d ",A[i]);
    }
 
    printf("\n\n");
 
    do {
        for (int t = 0; t < N-1; t++)
            if (A[t] > A[t+1]) swap(A[t],A[t+1]);
    }while(!issorted(A,N));
 
    for (int k = 0; k < N; k++)
        printf("%d ",A[k]);
    printf("\n");
 
    _getch();
 
    return 0;
}
http://liveworkspace.org/code/16214e...f7bc0a1e318605
frank_lampard
-8 / 2 / 0
Регистрация: 23.09.2012
Сообщений: 145
25.10.2012, 21:10  [ТС]     Метод попарно-обменной перестановки #3
zitxbit, спасибо большое!
Thinker
25.10.2012, 22:02     Метод попарно-обменной перестановки
  #4

Не по теме:

zitxbit,
1. сортировать надо было по убыванию.
2. лучше двигаться справа налево и выстроить левую границу.
3. зачем лишний цикл для проверки на упорядоченность, когда можно определить логическую переменную, отвечающую за наличие инверсий.

Yandex
Объявления
25.10.2012, 22:02     Метод попарно-обменной перестановки
Ответ Создать тему
Опции темы

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