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

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

01.04.2013, 00:03. Показов 1174. Ответов 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
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.04.2013, 00:03
Ответы с готовыми решениями:

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

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

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

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

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

К примеру

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  [ТС]
Цитата Сообщение от 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
261 / 236 / 161
Регистрация: 10.12.2011
Сообщений: 513
01.04.2013, 03:08
Уважаемый, вы что-то явно путаете, притом ещё и с правильного примера списать на можете
Вы повторили фактически ту же ситуацию что была до того. Вложенный цикл в данном контексте подразумевал сравнение первого элемента со всеми элементами второго массива, второго со всеми и т.д. до 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.04.2013, 03:08
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru