@Muriam

Как сделать, чтоб копия массива сортировалась слиянием?

Передача массива в функцию по ссылке.
в Dev-C++ компилируется, в Ideone - нет (даже после закомментирования getch)
в строке 55 надо выводить array2[i], а не array[i] ?

#include <iostream>
#include <conio.h>
#include <locale>
#include <ctime> //для таймера
#include <cstdlib> //для генерации рандомных чисел
#include <cstring>
#define SIZE 63

using namespace std;

int array[SIZE];
int array2[SIZE];
int n;

void random_array(int(&array)[SIZE]);
void insertion_sort(int(&array)[SIZE]);
void Merge(int(&array)[SIZE], int first, int last); //слияние массивов
void merge_sort(int(&array)[SIZE], int first, int last); //рекурсивная процедура сортировки

int main()
{
    //    long int start_time = clock(); 			// начальное время

    setlocale(LC_ALL, "rus");

    srand(time(0));

    random_array(array); //исходный массов
    cout << "\n\n";

    memcpy(array2, array, sizeof(int) * SIZE); //копия исходного массова
    cout << "копия исходного массива"
         << "\n";
    for (int i = 0; i < SIZE; i++) {
        cout << array2[i] << "  ";
    }
    cout << "\n";

    insertion_sort(array); //вызов сортировки вставками
    for (int i = 0; i < SIZE; i++) {
        cout << array[i] << "  ";
    }
    cout << "\n";

    merge_sort(array2, 1, n); //вызов сортировки слиянием
    for (int i = 0; i < SIZE; i++) {
        cout << array[i] << "  ";
    }

    /*
        long int end_time = clock();                    // конечное время	
        long int time1 = end_time - start_time;         // искомое время	
        cout << "\n" << "время работы программы " << time1 << " миллисекунд";
        float time2 = (float)time1 / 1000;
        cout << "\n" << "То есть, это составляет " << time2 << " секунд";
    */

    getch();
    return 0;
}

void random_array(int(&array)[SIZE])
{
    cout << "исходный массив" << endl;
    for (int i = 0; i < SIZE; i++) {
        array[i] = rand() % 100;
        cout << array[i] << " ";
    }
}

void insertion_sort(int(&array)[SIZE])
{
    cout << "\nотсортировано вставками" << endl;

    for (int i = 1; i < SIZE; i++) {
        int temp = array[i];
        int j = i - 1;
        while (j >= 0 && temp < array[j]) {
            array[j + 1] = array[j];
            j--;
        }
        array[j + 1] = temp;
    }
}

void Merge(int(&array)[SIZE], int first, int last)
{

    int middle, start, finall, j;

    int* mas = new int[SIZE];

    middle = (first + last) / 2; //вычисление среднего элемента
    start = first; //начало левой части
    finall = middle + 1; //начало правой части

    for (j = first; j <= last; j++) //выполнять от начала до конца
        if ((start <= middle) && ((finall > last) || (array[start] < array[finall]))) {
            mas[j] = array[start];
            start++;
        }
        else {
            mas[j] = array[finall];
            finall++;
        }

    //возвращение результата в список
    for (j = first; j <= last; j++)
        array[j] = mas[j];

    delete[] mas;
}

void merge_sort(int(&array)[SIZE], int first, int last)
{
    cout << "\nотсортировано слиянием" << endl;
    {
        if (first < last) {
            merge_sort(array, first, (first + last) / 2); //сортировка левой части
            merge_sort(array, (first + last) / 2 + 1, last); //сортировка правой части
            Merge(array, first, last); //слияние двух частей
        }
    }
};
  • Вопрос задан
  • 124 просмотра
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы