Форум программистов, компьютерный форум CyberForum.ru

Формировка массива по двум существующим - C++

Восстановить пароль Регистрация
 
Raikerian
9 / 9 / 1
Регистрация: 10.05.2011
Сообщений: 101
12.03.2012, 21:31     Формировка массива по двум существующим #1
В каждом из целочисленных массивов X и Y нет повторяющихся элементов. Сформировать массив Z, в который включить из X элементы, отсутствующие в Y, а из Y - элементы, отсутствующие в X.

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
// 1-3.cpp: Формировка массива Z из двух других
//
#include <iostream>
#include <stdlib.h>
#include <time.h>
using namespace std;
int main()
{
    setlocale(LC_ALL, "");
    srand(time(NULL));
    int sizeX, sizeY;
    cout << "Введите кол-во элементов в массивах (X и Y):" << endl;
    cin >> sizeX >> sizeY;
    int *X = new int [sizeX],
        *Y = new int [sizeY],
        i;
    cout << "\nМассив X:" << endl;
    for (i=0; i<sizeX; ++i)
    {
        *(X+i)=rand()%100-20;
        cout << *(X+i) << " ";
    }
    cout << "\n\nМассив Y:" << endl;
    for (i=0; i<sizeY; ++i)
    {
        *(Y+i)=rand()%100-20;
        cout << *(Y+i) << " ";
    }
    int j,
        k=-1,
        sizeZ = 100,
        *Z = new int [sizeZ];
    bool flag;
    // Взятие элементов из массива X
    for (i=0; i<sizeX; ++i);
    {
        flag = true;
        for (j=0; j<sizeY; ++j)
            if (*(X+i)==*(Y+j)) flag = false;
        if (flag)
        {
            k++;
            *(Z+k)=*(X+i);
        }
    }
    // Взятие элементов из массива Y
    for (i=0; i<sizeY; ++i);
    {
        flag = true;
        for (j=0; j<sizeX; ++j)
            if (*(Y+i)==*(X+j)) flag = false;
        if (flag)
        {
            k++;
            *(Z+k)=*(Y+i);
        }
    }
    cout << "\n\nПолученный массив Z:" << endl;
    for (i=0; i<k; ++i)
        cout << *(Z+i) << " ";
    delete [] X;
    delete [] Y;
    delete [] Z;
    cin.sync();
    cin.get();
    return 0;
}
Размерность массива Z почему то всегда выходит 1 а значение выводится одно и отрицательное, вообщем какаята ерунда. Просьба помочь отладить код
Миниатюры
Формировка массива по двум существующим  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.03.2012, 21:31     Формировка массива по двум существующим
Посмотрите здесь:

расчет по двум формулам C++
C++ Расчет по двум формулам
По двум заданным одномерным массивам формируется третий, содержащий в начале элементы первого, а в конце – элементы второго массива. C++
Как сделать ,чтобы строки двумерного массива были кратные двум? C++
Формировка третьего массива из двух других C++
C++ Получить массив из элементов другого массива, которые кратны двум
C++ Формировка однонаправленного Списка
C++ Рекурсивное вычисление. Найти среднее арифметическое по двум частям массива

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
12.03.2012, 21:53     Формировка массива по двум существующим #2
Цитата Сообщение от Raikerian Посмотреть сообщение
вообщем какаята ерунда.
Ну обычно какая-то ерунда - результат того что сами написали.
См комментарии:


Цитата Сообщение от Raikerian Посмотреть сообщение
C++
1
for (i=0; i<sizeX; ++i); // символ ; убираем
Цитата Сообщение от Raikerian Посмотреть сообщение
C++
1
for (i=0; i<sizeY; ++i); // символ ; убираем
остальное все получится.
Raikerian
9 / 9 / 1
Регистрация: 10.05.2011
Сообщений: 101
12.03.2012, 22:05  [ТС]     Формировка массива по двум существующим #3
Спасибо большое! Вы абсолютно правы, в данном случае я весьма невнимателен))
Yandex
Объявления
12.03.2012, 22:05     Формировка массива по двум существующим
Ответ Создать тему
Опции темы

Текущее время: 20:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru