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

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

08.07.2018, 19:37. Показов 6135. Ответов 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
9005 / 4706 / 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
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru