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

Объединить два массива

11.07.2016, 22:46. Показов 1705. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#include<iostream>
 
using namespace std;
 
int* BuildArray(int n){
    int* arr=new int[n];
    int flag = 0;
    while (flag != 1){
        flag = 1;
        cout << "Enter a array: ";
        for (int i = 0; i < n; i++)
            cin >> arr[i];
        for (int i = 1; i < n; i++)
            if (arr[i - 1] >= arr[i])
                flag = 0;
    }
    return arr;
}
 
void PrintArr(int* arr, int size){
    for (int i = 0; i < size; i++)
        cout << arr[i] << " ";
    cout << endl;
}
 
 
int* NewArray(int* arr1, int size, int* arr2, int size2,int* size3){
    int* arr;
    int n,i,j,k=0,l=0;
    n = size + size2;
    for (i = 0; i < size; i++){
        for (j = i; j < size2; j++){
            if (arr1[i] == arr2[j]){
                n--;
                break;
            }
        }
    }
    arr = new int[n];
    i = 0; j = 0;
    for (i = 0; i < size;){
        for (j = i; j < size2; j++){
            if (arr1[i] <= arr2[j]){
                arr[k] = arr1[i];
                k++;
                i++;
                break;
            }
            else if (arr1[i] > arr2[j]){
                arr[k] = arr2[j];
                k++;
                i++;
                break;
            }
        }
    }
    *size3 = n;
    return arr;
}
 
int main(){
    int *arr1, *arr2, *arr3;
    int size1, size2, size3;
    cout << "Enter a size of array 1: ";
    cin >> size1;
    arr1 = BuildArray(size1);
    PrintArr(arr1, size1);
    cout << "Enter a size of array 2: ";
    cin >> size2;
    arr2 = BuildArray(size2);
    PrintArr(arr2, size2);
    arr3 = NewArray(arr1, size1, arr2, size2, &size3);
    cout << "The new array is: " << endl;
    PrintArr(arr3, size3);
    delete[]arr1;
    delete[]arr2;
    delete[]arr3;
    return 0;
}
вот код, он должен взять два массива (выделены динамически) и сделать новый массив, в котором будут все числа двух массивов (в возрастающем порядке + не повторяться).
заранее спасибо.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.07.2016, 22:46
Ответы с готовыми решениями:

Объединить два массива
Есть 2 массива размерами и , первый заполнений случайными числами, нужно заполнить второй по принципу первые два элемента первого...

Объединить два массива
Даны два массива : А и B. Необходимо создать третий массив, в котором нужно собрать элементы обоих массивов

Объединить два упорядоченных массива
3. Даны два массива A и B размера 5, элементы которых упорядочены по убыванию. Объединить эти массивы так, чтобы результирующий массив...

4
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,244
12.07.2016, 07:34
Лучший ответ Сообщение было отмечено Timama как решение

Решение

Хорошая идея для этой задачи в качестве промежуточного массива использовать контейнер set, который автоматически игнорирует дубли и сортирует данные.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <set>
using namespace std;
int* NewArray(int* arr1, int size, int* arr2, int size2,int* size3)
{
    set<int> ts;
    for(int i=0;i<size;i++)
        ts.insert(arr1[i]);
    for(int i=0;i<size2;i++)
        ts.insert(arr2[i]);
    *size3=ts.size();
    int* result=new int[*size3];
    set<int>::iterator p=ts.begin();
    for(int i=0;i<*size3;i++)
        result[i]=*p++;
    return result;
}
1
Эксперт по математике/физикеЭксперт С++
 Аватар для Ilot
2224 / 1426 / 420
Регистрация: 16.05.2013
Сообщений: 3,646
Записей в блоге: 6
12.07.2016, 08:27
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 <iostream>
#include <algorithm>
#include <functional>
#include <random>
#include <iterator>
 
const int SIZE = 20;
 
int main() {
    int * array_one = new int[SIZE];
    int * array_two = new int[SIZE];
 
    std::default_random_engine generator;
    std::uniform_int_distribution<int> distribution(1,9);
 
    std::generate(array_one, array_one + SIZE, std::bind(distribution, generator));
    std::generate(array_two, array_two + SIZE, std::bind(distribution, generator));
 
    std::cout << "Source array: ";
    std::copy(array_one, array_one + SIZE, std::ostream_iterator<int>(std::cout, " "));
    std::endl(std::cout);
    std::cout << "Source array: ";
    std::copy(array_two, array_two + SIZE, std::ostream_iterator<int>(std::cout, " "));
    std::endl(std::cout);
 
    std::sort(array_one, array_one + SIZE);
    std::sort(array_two, array_two + SIZE);
 
    std::cout << "Sort array: ";
    std::copy(array_one, array_one + SIZE, std::ostream_iterator<int>(std::cout, " "));
    std::endl(std::cout);
    std::cout << "Sort array: ";
    std::copy(array_two, array_two + SIZE, std::ostream_iterator<int>(std::cout, " "));
    std::endl(std::cout);
 
    int * end_one_array = std::unique(array_one, array_one + SIZE);
    int * end_two_array = std::unique(array_two, array_two + SIZE);
 
    std::cout << "Unique array: ";
    std::copy(array_one, end_one_array, std::ostream_iterator<int>(std::cout, " "));
    std::endl(std::cout);
    std::cout << "Unique array: ";
    std::copy(array_two, end_two_array, std::ostream_iterator<int>(std::cout, " "));
    std::endl(std::cout);
 
    std::vector<int> cont;
    std::set_union(array_one, end_one_array,
                   array_two, end_two_array,
                   std::back_inserter(cont));
 
    std::cout << "Result array: ";
    std::copy(cont.begin(), cont.end(), std::ostream_iterator<int>(std::cout, " "));
}
1
 Аватар для Martein
704 / 109 / 21
Регистрация: 22.06.2014
Сообщений: 241
12.07.2016, 09:11
Александр Александрович, залогиньтесь. Человек изучает базовый синтаксис языка, прямой доступ к памяти через указатели и адресацию через квадратные скобки, что должно быть и ежу понятно. Никто ж про STL точенный не спрашивал.
0
12.07.2016, 19:08

Не по теме:

Martein, учить нужно хорошему с самого начала :D

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.07.2016, 19:08
Помогаю со студенческими работами здесь

Объединить два массива в один
Помогите с переводом pascal кода в C++ program prog0523b; uses crt; var x, y: array of integer; z: array of integer; ...

Объединить два одномерных массива C++
Доброго времени суток! вопрос такой...необходимо написать функцию для объединения 2-х одномерных массивов...передача параметров в функцию...

Объединить два упорядоченных массива
Пожалуйста, помогите сделать лабораторную по программированию с массивами на С++ Буду очень благодарен( 2.Даны два массива А и В...

Как объединить два двумерных массива?
есть массивы А и B как их зделать в C, проста смотрел про одномерные массивы там все както проста но не пордходит к двухмерному даже...

Объединить два массива отсортированных по убыванию
Дана массивы a и b. Элементы массива a отсортированы в порядке убывания, массива b – в порядке возрастания. Образовать из этих массивов...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
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
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru