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

Cоздать массив минимально возможного размера, поместив в него общие элементы двух исходных массивов без повторений

08.07.2018, 19:37. Показов 6174. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день ,я немного запутался в решении. Помогите, если кто понимает, заранее благодарен. Вот задача Даны два массива: А[M] и B[N] (M и N вводятся с клавиатуры). Необходимо создать третий массив минимально возможного размера, в котором нужно собрать общие элементы двух массивов без повторений. МОЙ ВОПРОС В КОММЕНТАРИЯХ в коде
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
80
81
82
83
84
85
86
87
#include "stdafx.h"
#include <iostream>
#include <ctime>
void randomize(int*, int);
using namespace std;
int main()
{
int a = 10;
    int b = 7;
    int *arr_a = new int[a]; //размеры массивов
    int *arr_b = new int[b];
    srand(int(time(0)));
    cout << " Array A : " << endl;
    randomize(arr_a, a); //выведу  их на экран
    cout << endl;
    cout << " Array B : " << endl;
    randomize(arr_b, b);
    cout << endl;
 
    int counter = 0;
    bool isExists = false;
 
    for (int i = 0; i < a; i++) {
 
        for (int j = 0; j < b; j++) {
            if (*(arr_a+i) == *( arr_b+j)) isExists = true;
        }
        if (isExists == false) counter++; //узнаю макс возможный размер будущего массива 
        isExists = false;
    }
    int *arr_c = new int[counter];
    
    int idx = 0;
 
    for (int i = 0; i < a; i++) {
        for (int j = 0; j < b; j++) {
            if (*(arr_a + i) == *(arr_b + j)) isExists = true; //посмотрю нет ли совпадений цифр в двух массивах 
        }
        if (isExists == false) *(arr_c+idx++) = *(arr_a+i);
        isExists = false;
    }
 
    for (int i = 0; i < b; i++) {
        for (int j = 0; j < a; j++) {
            if (*(arr_b+i) == *(arr_a+j)) isExists = true;
        }
        if (isExists == false) *(arr_c + idx++) = *(arr_b + i); //аналогичное действие , но только с массивом В
        isExists = false;
    }
//В этом блоке проверяю, чтобы в окончательном массиве не повторялись цифры и вот проблема, если одинаковых цифр больше 3 и они уникальны, то они вообще не выводятся на экран , т.е , если например две уникальных девятки в массиве, то выводиться одна , а если уникальных девяток больше трех , то они вообще игнорируются . КАК ЭТО ИСПРАВИТЬ ? 
    int check = 0;
    int idx1 = 0;
    isExists = false;
    for (int i = 0; i < idx; i++) {
        for (int j = 0; j < idx; j++) {
            if (*(arr_c +i) == *(arr_c+j) && i != j) {
                if (check > 1) {
                    isExists = true;
                    check = 0;
                }
                check++;
                
            }
        }
        if (isExists == false) *(arr_c +idx1++) = *(arr_c+i);
        isExists = false;
    }
 
    cout << " Array C : " << endl;
    for (int i = 0; i < idx1; i++) {
        cout << *(arr_c+i) << " ";
    }
    if (idx1 == 0) cout << " NO ELEMENTS FOUND ";
    cout << endl;
 
    system("pause");
    return 0;
}
 
void randomize(int *arr, int size)
{
    for (int i = 0; i < size; i++) {
        *(arr + i) = rand() % 10;
        cout << *(arr + i) << " ";
    }
    cout << endl;
}
ПРОШУ не использовать сложных функций и решений, библ функции для удаления элементов не подходят в решение
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.07.2018, 19:37
Ответы с готовыми решениями:

Создать массив минимально возможного размера, в котором нужно собрать общие элементы двух заданных массивов
Даны два массива: А и B (M и N вводятся с клавиатуры). Необходимо создать третий массив минимально возможного размера, в котором...

Переписать в третий массив общие элементы первых двух массивов без повторений
Даны 2 массива размерности M и N соответственно. Необходимо переписать в третий массив общие элементы первых двух массивов без...

Необходимо переписать в третий массив общие элементы первых двух массивов без повторений
не выводит 3-й массив..(((( В чем трудность не понимаю.... #include&lt;iostream&gt; #include&lt;ctime&gt; using namespace std; void...

3
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9006 / 4707 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
08.07.2018, 19:59
Лучший ответ Сообщение было отмечено steptrainee как решение

Решение

steptrainee, в данной задаче самое интересное, это подсчёт уникальных значений. После этого легко выделить необходимую память и итерируя по исходным массивам, добавлять только то значение, которого в выходном массиве ещё нет.
Подсчёт можно провести поразному. Например, итерируя по обоим массивам, проверяем встретится ли от текущего положения такое же значение впереди хотя бы ещё раз. Если да, то инкрементируем итератор значений и проверяем новое значение. Если данное значение больше не встречается - инкрементируем счётчик - размер будущего массива в динамическуой памяти.
1
1394 / 1023 / 325
Регистрация: 28.07.2012
Сообщений: 2,813
08.07.2018, 20:02
Лучший ответ Сообщение было отмечено steptrainee как решение

Решение

steptrainee,
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
#include <iostream>
#include <algorithm>
 
using namespace std;
 
bool in_array(int *pArr, int n, int elem)
{
    for (int i = 0; i < n; ++i)
    {
        if (pArr[i] == elem)
            return true;
    }
    return false;
}
 
int main()
{
    int a = 3;
    int b = 3;
    int *arr_a = new int[a];
    int *arr_b = new int[b];
    int *arr_c = new int[max(a, b)];
    int c_size = 0;
    cout << " Array A : " << endl;
    for (int i = 0; i < a; ++i)
        cin >> arr_a[i];
    cout << " Array B : " << endl;
    for (int i = 0; i < b; ++i)
        cin >> arr_b[i];
 
    for (int i = 0; i < a; ++i)
    {
        if (in_array(arr_b, b, arr_a[i]) && !in_array(arr_c, c_size, arr_a[i]))
            arr_c[c_size++] = arr_a[i];
    }
 
    cout << "Result: " << endl;
    for (int i = 0; i < c_size; ++i)
        cout << arr_c[i] << " ";
    cout << endl;
 
    return 0;
}
2
2 / 2 / 0
Регистрация: 03.05.2018
Сообщений: 101
08.07.2018, 22:40  [ТС]
Классное решение , спасибо!

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

Создать третий массив минимально возможного размера, в котором нужно собрать элементы обоих массивов
Даны два массива: А и B (M и N вводятся с клавиатуры). Необходимо создать третий массив минимально возможного размера, в котором нужно...

Создать третий массив минимально возможного размера, в котором нужно собрать элементы обоих массивов
2. Даны два массива: А и B (M и N вводятся с клавиатуры). Необходимо создать третий массив минимально возможного размера, в котором нужно...

Создать третий массив минимально возможного размера, в котором нужно собрать элементы обоих массивов
Вот Задача Даны два массива: А и B (M и N вводятся с клавиатуры). Необходимо создать третий массив минимально возможного размера, в...

Создать динамический массив нужного размера и скопировать в него все положительные элементы из первых двух массивов
Решить задачи через Указатели... 1. Программа должна создать два массива со случайными элементами из диапазона , по 10 элементов в...

Поместить в третий массив общие элементы двух массивов
здравствуйте. никак не могу додуматься как написать цикл по перебору элементов массива. Задача такая: есть два динамических массива. Нужно...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Семь 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. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru