Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
81 / 81 / 33
Регистрация: 03.03.2013
Сообщений: 311
1

Создать одномерный массив, в котором находятся повторяющиеся элементы двух известных массивов

01.04.2013, 00:03. Просмотров 778. Ответов 3
Метки нет (Все метки)

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
#include <stdio.h>
#include <conio.h>
#define max 100
main()
{
unsigned M1[max],M2[max],M3[max],i,j=0,n;
printf("n=");
scanf("%i",&n);
for(i=0;i<n;i++)
 {
 printf("M1[%i]=",i);
 scanf("%d",&M1[i]);
 printf("M2[%i]=",i);
 scanf("%d",&M2[i]);
 if (M1[i]==M2[i])
  {
  M3[j]=M1[i];
  j++;
  };
 };
 printf("new:\n");
 for(i=0;i<j;i++) printf("%i\t",M3[i]);
 getch();
 return 0;
 }
У меня только получилось сравнять елементы массивов с одинаковыми номерами, помогите, пожалуйста, зделать так, что бы сравнивать все елементы массивов.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.04.2013, 00:03
Ответы с готовыми решениями:

Создать массив, в котором присутствуют только совпадающие элементы двух известных одномерных массивов
Надо создать массив, в котором присутствуют только елементы двух известных одномерных массивов....

Создать массив, в котором нужно собрать элементы двух заданных массивов
Подскажите, пожалуйста, как решить следующую задачу с помощью ссылок и операторов new и delete ...

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

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

3
260 / 235 / 161
Регистрация: 10.12.2011
Сообщений: 513
01.04.2013, 01:00 2
Вы лучше там где инициализируете массив их не сравнивайте.

Создайте массивы, а уже потом циклом + вложенным циклом сравнивайте со всеми.

К примеру

C++
1
2
3
4
5
int j = 0;
for ( int i = 0; i < n ; i++)
{
    for ( int k = 0; k < n ; k++ ) if (Mas1[i] == Mas2[k]) Mas3[j++] = Mas1[i];
}
1
81 / 81 / 33
Регистрация: 03.03.2013
Сообщений: 311
01.04.2013, 01:43  [ТС] 3
Цитата Сообщение от Leshak Посмотреть сообщение
Вы лучше там где инициализируете массив их не сравнивайте.

Создайте массивы, а уже потом циклом + вложенным циклом сравнивайте со всеми.

К примеру

C++
1
2
3
4
5
int j = 0;
for ( int i = 0; i < n ; i++)
{
    for ( int k = 0; k < n ; k++ ) if (Mas1[i] == Mas2[k]) Mas3[[COLOR="Red"]j++[/COLOR]] = Mas1[i];
}
Так не получится, ведь надо в массив загнать начиная с нулевого номера. Хочу зделать вот так:
C++
1
2
3
4
5
6
7
for(i=0;i<n;i++) 
 {
  for(k=0;k<n;k++) if (M1[i]==M2[k])
   {
   M3[j]=M1[i]; j++
   };
 };
но чтото не получается, помогите кто-нибудь, пожалуйста.
0
260 / 235 / 161
Регистрация: 10.12.2011
Сообщений: 513
01.04.2013, 03:08 4
Уважаемый, вы что-то явно путаете, притом ещё и с правильного примера списать на можете
Вы повторили фактически ту же ситуацию что была до того. Вложенный цикл в данном контексте подразумевал сравнение первого элемента со всеми элементами второго массива, второго со всеми и т.д. до n - 1.
И уже если о правильности говорить то скобочки не вначале второго цикла надо было ставить, а после условия в условном операторе.

C++
1
2
3
4
5
6
7
8
9
10
int j = 0;
for(i=0;i<n;i++) 
{
  for(k=0;k<n;k++) 
    if (M1[i]==M2[k])
   {
       M3[j]=M1[i]; 
       j++
    }
}
Вот теперь, что-то должно получится.

Добавлено через 18 минут
A про скобочки извиняюсь =)
Скиньте тогда весь код программы.

Добавлено через 18 минут
Ладно, я понял. Сделал за вас
Некоторые моменты ввода вывода, думаю вы исправите сами на Сишные.
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
#include "stdafx.h"
#include <iostream>
 
int main()
{
    const int Nmax = 100;
    int Mas1[Nmax],Mas2[Nmax], Mas3[Nmax], n;
    std::cout<<"Enter Size:";std::cin>>n;
    for ( int i = 0; i < n ; i++){
        std::cout<<"Mas1["<<i<<"]";std::cin>>Mas1[i];
        std::cout<<"Mas2["<<i<<"]";std::cin>>Mas2[i];
    }
    std::cout<<"\nMas1:\n";
    for ( int i = 0; i < n ; i++){
        std::cout<<Mas1[i]<<" ";
    }
    std::cout<<"\nMas2:\n";
    for ( int i = 0; i < n ; i++){
        std::cout<<Mas2[i]<<" ";
    }
    int j = 0;
    for (int i = 0; i < n ; i++){
      for (int k = 0; k < n ; k++) if (Mas1[i] == Mas2[k])  Mas3[j++] = Mas1[i];
    }
    std::cout<<"\nMas3\n";
    for (int i = 0; i < j ; i++)std::cout<<Mas3[i]<<" ";
    std::cout<<"\n";
    system("pause");
    return 0;
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.04.2013, 03:08

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Создать одномерный массив и удалить из него повторяющиеся элементы
Здравствуйте! Только начал изучать массивы в c++. Поставили задачу создать одномерный массив и...

Из двух массивов создать один, в котором вначале идут четные элементы, затем нечетные
Заданы два массива. Создать один массив, в котором вначале идут четные элементы, затем нечетные.

Создать третий массив, в котором собрать элементы двух предыдущих
Есть два одномерных динамических массива: А и B. Необходимо создать третий массив С, в котором надо...

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


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

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

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