Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/15: Рейтинг темы: голосов - 15, средняя оценка - 4.60
Заблокирован

Слияние двух отсортированых массивов в один

25.06.2013, 14:48. Показов 3329. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
задание: Задано два массива. Массив А состоит из N элементов и отсортированный по увеличению . Массив В состоит из N элементов и отсортированный по уменьшению. Разработать программу для слияния этих массивов в отсортированный по уменьшению массив С который не имеет одинаковых элементов.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.06.2013, 14:48
Ответы с готовыми решениями:

Слияние из двух массивов в один общий
Требуется соединить два массива в один есть сложность что они считаны с файла... помогите объединить два массива в один и вывести его на...

Слияние двух массивов
Всем привет. Возникла проблема с задачей. Даны два массива одинакоого размера. Нужно создать 3 массив который будет хранить элементы...

Слияние двух динамических массивов…
Приветствую Вас!:) Задача такая: Даны два массива: A и B (числовые), упорядоченные по неубыванию. Слить их в один упорядоченный...

5
:)
Эксперт С++
4773 / 3267 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
25.06.2013, 15:01
std::sort + std::merge + std::unique
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.06.2013, 15:28
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
#include<iostream>
const int NA = 5;
const int NB = 7;
const int NC = 12;
 
void Merge(int *a, int na, int *b, int nb, int *c, int &nc)
{
   int i = na - 1, j = 0, k = 0;
   if (a[i] > b[j])
      c[k++] = a[i--];
   else c[k++] = b[j++];
   while (i >= 0 && j < nb)
      if (a[i] == c[k - 1])
         --i;
      else if (b[j] == c[k - 1])
         j++;
      else if (a[i] > b[j])
         c[k++] = a[i--];
      else
         c[k++] = b[j++];
   if (j == nb)
   {
      for(j = i; j >= 0; --j)
         if (a[j] != c[k])
            c[k++] = a[j];
   }
   else
   {
      for(i = j; i < nb; ++i)
         if (b[i] != c[k - 1])
            c[k++] = b[i];
   }
   nc = k;
}
 
void Print(int *a, int n)
{
   for(int i = 0; i < n; ++i)
      std::cout << a[i] << " ";
   std::cout << std::endl;      
}
 
int main()
{
   int a[NA] = {1, 2, 2, 3, 3}, b[NC] = {10, 10, 7, 7, 7, 1 ,1}, c[NC], nc;
   Print(a, NA);    
   Print(b, NB);
   Merge(a, NA, b, NB, c, nc);  
   Print(c, nc);    
}
0
:)
Эксперт С++
4773 / 3267 / 497
Регистрация: 19.02.2013
Сообщений: 9,046
25.06.2013, 15:36
А вот мой вариант:
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
#include <iostream>
#include <cstdlib>
#include <algorithm>
#include <vector>
#include <iterator>
 
int main() {
    
    const int N = 5;
 
    int a[N] = { 1,2,3,4,9 };
    int b[N] = { 8,7,6,5,4 };
 
    std::vector<int> c;
 
    int* ai = &a[N-1];
    int* bi = &b[0];
 
    while( ai != &a[-1] && bi != &b[N] )
    {
        if( *ai == *bi )
        {
            c.push_back( *ai );
            ai--;
            bi++;
        }
        else if( *ai < *bi )
        {
            c.push_back( *bi );
            bi++;
        }
        else
        {
            c.push_back( *ai );
            ai--;
        }
    }
 
    while( ai != &a[-1] )
    {
        c.push_back( *ai );
        ai--;       
    }
 
    while( bi != &b[N] )
    {
        c.push_back( *bi );
        bi++;
    }
 
    std::copy( c.begin(), c.end(), std::ostream_iterator<int>( std::cout, " " ) );
 
    std::system( "pause" );
    return 0;
}
P.S. Правда у меня не допускаются дубли в исходных массивах.
0
138 / 130 / 59
Регистрация: 13.12.2012
Сообщений: 293
25.06.2013, 15:42
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
#include <iostream>
using std::cout;
using std::endl;
#include <iomanip>
using std::setw;
 
const int N1=8, N2=10;
 
int main()
{
    short arr1[N1]={-7,-5,-5,-5,-3,0,0,7};
    short arr2[N2]={9,8,7,6,4,4,4,4,-5,-5};
    short arr3[N1+N2];
 
    int count1=N1-1,count2=0,count3=0;
    while (count1>=0 && count2<N2)
    {
        if (arr1[count1]>arr2[count2])
            arr3[count3++]=arr1[count1--];
        else
            arr3[count3++]=arr2[count2++];
        if (count3>=2 && arr3[count3-1]==arr3[count3-2])
            count3--;
    }
    if (!(count1>=0))
        for (int i=count2;i<N2;i++)
            if (count3>0 && arr3[count3-1]!=arr1[i])
            arr3[count3++]=arr2[i];
    if (!(count2<N2))
        for (int i=count1;i>=0;i--)
            if (count3>0 && arr3[count3-1]!=arr1[i])
                arr3[count3++]=arr1[i];
 
    for (int i=0;i<count3;i++)
        cout<<setw(3)<<arr3[i];
    cout<<endl;
}
0
 Аватар для OstapBender
594 / 532 / 76
Регистрация: 22.03.2011
Сообщений: 1,585
25.06.2013, 16:50
можно залить в std::set, оно сразу откинет повторения и хранится там все в сортированном виде
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.06.2013, 16:50
Помогаю со студенческими работами здесь

Слияние двух отсортированных массивов в третий
Здравствуйте всем! Только начинаю изучать языки программирования. Помогите найти ошибку. Необходимо создать два массива, слить и...

Слияние двух массивов, решение с помощью указателей
помогите,пожалуйста,решить! Задан массив A из N элементов и массив B из M элементов. Сформировать массив L из массивов A и B путем их...

Слияние двух массивов в отсортированный по не убыванию массив
Даны два массива. Массив А состоит из N элементов, массив В состоит из М элементов. Оба массива отсортированы по убыванию. Разработать...

Слияние двух массивов, заполненных случайными числами, в третий
Доброго времени суток,подскажите,возможно кто то знает как решить задачу ниже..у самого ничего не получается.. Заранее Большое Спасибо! ...

слияние двух упорядоченных массивов в один упорядоченный
это слияние двух упорядоченных массивов в один упорядоченный, программу я сама напишу, тока помогите немного врубиться Program...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru