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

Объединить 2 массива в один, в котором все числа идут по убыванию - C++

Восстановить пароль Регистрация
 
 
Sh@dow777
11 / 11 / 3
Регистрация: 10.12.2013
Сообщений: 645
09.06.2014, 22:56     Объединить 2 массива в один, в котором все числа идут по убыванию #1
Привет всем. Мне нужно объединить 2 массива в один, в котором все числа идут по убыванию. Вот подробности задачи.

Текстовый файл merge.dat содержит четыре строки. В первой строке записано натуральное число N (1 ≤ N ≤ 100 000) — количество дуболомов в первой шеренге.

Вторая строка содержит N натуральных чисел, записанных через пробел. Числа идут в невозрастающем порядке. Каждое число лежит в диапазоне от 1 до 1 000 000 000.

В третьей строке записано натуральное число M (1 ≤ M ≤ 100 000) — количество дуболомов во второй шеренге.

Четвертая строка содержит M натуральных чисел, записанных через пробел. Числа идут в невозрастающем порядке. Каждое число лежит в диапазоне от 1 до 1 000 000 000.

Формат выходного файла merge.sol

Текстовый файл merge.sol должен содержать N+M чисел, идущих в невозрастающем порядке. Каждое число — это рост соответствующего дуболома из первой или из второй шеренги. Каждое число должно выводиться в отдельную строку.

У меня есть предположения, что раз числа идут в невозрастающем порядке, то 2 массива нужно сначала отсортировать по убыванию, а потом слить вместе процедурой слияния.
Я так понимаю, что для слияния нужно использовать этот код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
template<class T> void Merge(T const *const A, int const nA,
                             T const *const B, int const nB,
                             T *const C)
{ //Выполнить слияние массива A, содержащего nA элементов,
  //  и массива B, содержащего nB элементов.
  //  Результат записать в массив C.
 
    int a(0), b(0); //Номера текущих элементов в массивах A и B
 
    while( a+b < nA+nB ) //Пока остались элементы в массивах
    {
        if( (b>=nB) || ( (a<nA) && (A[a]<=B[b]) ) )
        { //Копирую элемент из массива A
            C[a+b] = A[a];
            ++a;
        } else { //Копирую элемент из массива B
            C[a+b] = B[b];
            ++b;
        }
    }
}
Скажите, этот код подходит? Если да, то как изменить его, чтоб числа в массиве С шли по убыванию?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.06.2014, 22:56     Объединить 2 массива в один, в котором все числа идут по убыванию
Посмотрите здесь:

За один просмотр символов строки найти все самые длинные слова, символы в которых идут в строгом возрастании кодов C++
объединить три 2-мерных массива в один 3-мерный массив C++
C++ Получить новый массив, в котором сначала идут положительные числа, затем нулевые, затем отрицательные исходного
Объединить элементы 2-х массивов в один массив, содержащий все различные числа C++
C++ Как объединить два массива в один?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
10.06.2014, 17:07     Объединить 2 массива в один, в котором все числа идут по убыванию #21
Цитата Сообщение от Sh@dow777 Посмотреть сообщение
Та же ошибка.
И? Вопрос в чём? Отчего возникает такая ошибка? Ответ:
Цитата Сообщение от Sh@dow777 Посмотреть сообщение
HEAP CORRUPTION DETECTED
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ValeryS
Модератор
6377 / 4843 / 442
Регистрация: 14.02.2011
Сообщений: 16,048
10.06.2014, 17:19     Объединить 2 массива в один, в котором все числа идут по убыванию #22
Цитата Сообщение от Sh@dow777 Посмотреть сообщение
Так мне нужно long long, так как
Цитата Сообщение от Sh@dow777 Посмотреть сообщение
Каждое число лежит в диапазоне от 1 до 1 000 000 000.
ну и зачем тебе long long ???
диапазон числа int от -2147483648 до 2147483647
Цитата Сообщение от Sh@dow777 Посмотреть сообщение
int *a = new int[n];
выделяем память под int
Цитата Сообщение от Sh@dow777 Посмотреть сообщение
scanf("%lld", &a[i]);
вводим long long
ниче что он в два раза длиннее?
в массиве каша
Sh@dow777
11 / 11 / 3
Регистрация: 10.12.2013
Сообщений: 645
10.06.2014, 17:23  [ТС]     Объединить 2 массива в один, в котором все числа идут по убыванию #23
alsav22, Я не понял вас. Во второй программе я ввожу размер массива, элементы массива и массив потом сортируется алгоритмом слияния. После ввода элементов массива и нажатия Enter выводит ошибку
Цитата Сообщение от alsav22 Посмотреть сообщение
HEAP CORRUPTION DETECTED
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
10.06.2014, 17:25     Объединить 2 массива в один, в котором все числа идут по убыванию #24
Цитата Сообщение от Sh@dow777 Посмотреть сообщение
Я не понял вас.
Странно, что не поняли...
Запись за границу памяти (j не должно быть равно last):
C++
1
2
3
4
5
6
7
8
int *mas=new int[last];
...
for (j = first; j <= last; j++)
{
    ....
    mas[j] = 
...
}
Чтение оттуда же:
C++
1
2
3
4
for (j = first; j <= last; j++)
{
      A[j] = mas[j];
     ...
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.06.2014, 17:32     Объединить 2 массива в один, в котором все числа идут по убыванию
Еще ссылки по теме:

Объединить два упорядоченных по неубыванию массива в один C++
C++ Объединить два упорядоченных массива в один
Два двумерных массива объединить в один двумерный C++

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

Или воспользуйтесь поиском по форуму:
Sh@dow777
11 / 11 / 3
Регистрация: 10.12.2013
Сообщений: 645
10.06.2014, 17:32  [ТС]     Объединить 2 массива в один, в котором все числа идут по убыванию #25
ValeryS, alsav22, Спасибо вам. И действительно, все дело было в long long.
Yandex
Объявления
10.06.2014, 17:32     Объединить 2 массива в один, в котором все числа идут по убыванию
Ответ Создать тему
Опции темы

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