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

Собрать элементы массива A отсутствующие в массиве B

14.11.2021, 16:38. Показов 938. Ответов 3

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

Ребят, подправьте код, вылазит ошибка. И что бы код работал даже если 1 массив больше 2 массива и наоборот

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
    int size1 = 0, size2 = 0;
    cout << "Введите размер 1 массива :";
    cin >> size1;
    cout << "Введите размер 2 массива :";
    cin >> size2;
    int* array1 = new int[size1];
    int* array2 = new int[size2];
    cout << "Первый массив :";
    for (int i = 0; i < size1; i++)
    {
        array1[i] = rand() % 9 + 1;
        cout << array1[i] << "  ";
    }
    cout << endl;
    cout << "Второй массив :";
    for (int i = 0; i < size2; i++)
    {
        array2[i] = rand() % 9 + 1;
        cout << array2[i] << "  ";
    }
    cout << endl;
    int size3 = 0;
 
    int* array3Copy = new int[size3];
 
    for (int i = 0; i < size1,i < size2; i++)
    {
        
        if (array1[i] != array2[i]) {
            array3Copy[size3] = array1[i];
            size3++;
        }
        
    }
 
    for (int i = 0; i < size3; i++)
    {
        cout << array3Copy[i] << " ";
    }
 
 
 
    delete[] array2;
    delete[] array1;
    delete[] array3Copy;
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.11.2021, 16:38
Ответы с готовыми решениями:

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

Необходимо собрать в третьем массиве, элементы массива А, которые не включаются в массив B
Необходимо собрать в третьем массиве, элементы массива А, которые не включаются в массив B. Помогите с решением, мое выдает массив А и все,...

Найти элементы массива отсутствующие в другом массиве
У меня два массива: 1) arr на 18 элементов 2)foo на 7 элементов надо вывести на экран или в файл элементы которые не повторяются!!!!...

3
1 / 1 / 0
Регистрация: 12.11.2021
Сообщений: 12
14.11.2021, 16:50
Цитата Сообщение от Amadeyy Посмотреть сообщение
if (array1[i] != array2[i]) {
            array3Copy[size3] = array1[i];
            size3++;
        }
в начале size3 = 0 то array3Copy не имеет элементов и нулевого элемента не существует.
попробуйте поменять местами array3Copy[size3] = array1[i] и size3++.
0
0 / 0 / 0
Регистрация: 02.11.2021
Сообщений: 15
14.11.2021, 17:08  [ТС]
PuShO4Ek, все равно ничего не работает

Добавлено через 6 минут
Я видимо самого задания не понял до конца и как это в коде реализовать
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
14.11.2021, 17:41
Лучший ответ Сообщение было отмечено Amadeyy как решение

Решение

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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
void random (int *x, int n)
{
    for (int i = 0; i < n; i++)        
        x[i]=rand()%9 + 1;
}
 
void print (int *x, int n)
{
    for (int i = 0; i < n; i++)             
        cout << x[i] << " ";        
    cout << "\n";    
} 
 
int main()
{
    srand((int)time(0));
    int N, M, K=0, u=0, t;
    cout << "M="; cin >> M;
    cout << "N="; cin >> N;
    
    int* A = new int[M];
    int* B = new int[N];    
    
    random(A,M);
    random(B,N);    
    cout << "Array A:\n";
    print(A,M);   
    cout << "Array B:\n";
    print(B,N);    
    
    for (int i = 0; i < M - 1; i++)
        for (int j = i + 1; j < M; j++)
            if (A[i] == A[j])
            {
                for (int p = j; p < M; p++)
                    A[p] = A[p + 1];
                M--;
                j--;
            }   
    
    for (int i = 0; i < M; i++)
    {
        t=0;
        for (int j = 0; j < N; j++)
            if(A[i]==B[j]) {t=1;break;}
        if(t==0) K++;
    }    
        
    if(K)
    {        
        int* C = new int[K];
        
        cout << "New array:\n";
        for (int i = 0; i < M; i++)
        {
            t=0;
            for (int j = 0; j < N; j++)
                if(A[i]==B[j]) {t=1;break;}
            if(t==0) C[u++]=A[i];
        }    
        
        print(C,K);
        delete[]C;    
     }
     else cout << "Array A doesn't contain such elements\n";
 
     delete[]A;
     delete[]B;    
system("pause");
return 0;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.11.2021, 17:41
Помогаю со студенческими работами здесь

Сформировать массив С, который должен содержать элементы массива A, отсутствующие в массиве B
Всем доброго времени суток:), прошу помочь с задачей в Windows Forms - &quot;Ввести два одномерных целочисленных массива A и B из N и M...

Сформировать массив Z, в который включить из X элементы, отсутствующие в Y, а из Y - элементы, отсутствующие в X
В каждом из целочисленных массивов X и Y нет повторяющихся элементов. Сформировать массив Z, в который включить из X элементы,...

Сформировать массив Z, в который включить из X элементы, отсутствующие в Y, а из Y - элементы, отсутствующие в X
В каждом из целочисленных массивов X(n) и Y(m) нет повторяющихся элементов. Сформировать массив Z, в который включить из X элементы,...

Отсутствующие элементы массива
Задание звучит так: составить 2 массива и 3й массив, элементами которого будут те числа массива #2, которые отсутствуют в массиве #1. Вот...

Вывести отсутствующие элементы массива
Собственно есть массив, скажем a={1,3,4,5,6}. Нужно сформировать второй массив такой же размерности, элементы которого будут недостающие...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru