Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/18: Рейтинг темы: голосов - 18, средняя оценка - 4.67
1 / 1 / 0
Регистрация: 03.05.2018
Сообщений: 101
1

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

08.07.2018, 19:37. Показов 3448. Ответов 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

Помощь в написании контрольных, курсовых и дипломных работ здесь.

Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.07.2018, 19:37
Ответы с готовыми решениями:

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

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

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

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

3
Комп_Оратор)
Эксперт по математике/физике
8719 / 4428 / 598
Регистрация: 04.12.2011
Сообщений: 13,276
Записей в блоге: 16
08.07.2018, 19:59 2
Лучший ответ Сообщение было отмечено steptrainee как решение

Решение

steptrainee, в данной задаче самое интересное, это подсчёт уникальных значений. После этого легко выделить необходимую память и итерируя по исходным массивам, добавлять только то значение, которого в выходном массиве ещё нет.
Подсчёт можно провести поразному. Например, итерируя по обоим массивам, проверяем встретится ли от текущего положения такое же значение впереди хотя бы ещё раз. Если да, то инкрементируем итератор значений и проверяем новое значение. Если данное значение больше не встречается - инкрементируем счётчик - размер будущего массива в динамическуой памяти.
1
1360 / 997 / 316
Регистрация: 28.07.2012
Сообщений: 2,759
08.07.2018, 20:02 3
Лучший ответ Сообщение было отмечено 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
1 / 1 / 0
Регистрация: 03.05.2018
Сообщений: 101
08.07.2018, 22:40  [ТС] 4
Классное решение , спасибо!

Добавлено через 31 минуту
Прокомментируйте ,пожалуйста, строку 33
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
08.07.2018, 22:40

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.