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

Слияние массивов

05.12.2019, 19:06. Показов 997. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть задача: Описать функцию, которая выполнит слияние двух массивов одинаковой длины в третьем (элементы первого и второго массивов в нем чередуются).
У меня есть программа, но без функции. Помогите пожалуйста ее сделать через функцию.
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
#include <cmath>
#include <iostream>
#include <math.h>
#include <locale>
#include <conio.h>
using namespace std;
int main()
{
    //Cлияние двух массивов одинаковой длины в третьем(элементы первого и второго массивов в нем чередуются).
    int n, m;
    setlocale(LC_ALL, ".1251");
    cout << "Задание 2" << endl;
    cout << "Введите размер первого массива: ";
    cin >> n;
    cout << "Введите размер второго массива: ";
    cin >> m;
    int *a = new int[n];
    int *b = new int[m];
    cout << "Введите первый массива: ";
    for (int i = 0; i < n; i++) {
        cin >> a[i];
    }
    cout << "Введите второй массива: ";
    for (int i = 0; i < m; i++) {
        cin >> b[i];
    }
    int *result = new int[n + m];
    int i = 0, j = 0;
    int index = 0;
    while (i < n && j < m) {
        if (a[i] < b[j]) {
            result[index] = a[i];
            i++;
        }
        else {
            result[index] = b[j];
            j++;
        }
        index++;
    }
    while (i < n) {
        result[index] = a[i];
        index++;
        i++;
    } while (j < m) {
        result[index] = b[j];
        index++;
        j++;
    }
    for (int k = 0; k < n + m; k++) {
        cout << result[k] << ' ';
    }
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.12.2019, 19:06
Ответы с готовыми решениями:

Слияние массивов
я новичек в программировании. Помогите пожалуйста решить слудеющию задачу на С++. Заданы три упорядоченных по возрастанию массива f,...

Слияние массивов
Задан массив A из N элементов и массив B из M элементов. Сформировать массив L из массивов A и B путем их слияния так, чтобы сначала...

Слияние массивов
Даны два массива. Массив А состоит из N элементов и отсортирован по возрастанию. Массив В состоит из М элементов и отсортирован по...

5
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
05.12.2019, 19:19
Цитата Сообщение от 7heWh1t3 Посмотреть сообщение
Помогите пожалуйста ее сделать через функцию
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
#include <cmath>
#include <iostream>
#include <math.h>
#include <locale>
#include <conio.h>
 
using namespace std;
 
int* Merger(int* a, int* b, std::size_t size)
{
    int *result = new int[size + size];
 
    int i = 0, j = 0;
    int index = 0;
    while (i < size) {
        if (a[i] < b[j]) {
            result[index] = a[i];
            i++;
        }
        else {
            result[index] = b[j];
            j++;
        }
        index++;
    }
    while (i < size) {
        result[index] = a[i];
        index++;
        i++;
    } while (j < size) {
        result[index] = b[j];
        index++;
        j++;
    }
 
    return result;
}
 
int main()
{
    //Cлияние двух массивов одинаковой длины в третьем(элементы первого и второго массивов в нем чередуются).
    int n, m;
    setlocale(LC_ALL, ".1251");
    cout << "Задание 2" << endl;
    cout << "Введите размер массива: ";
    cin >> n;
    int *a = new int[n];
    int *b = new int[n];
    cout << "Введите первый массива: ";
    for (int i = 0; i < n; i++) {
        cin >> a[i];
    }
    cout << "Введите второй массива: ";
    for (int i = 0; i < n; i++) {
        cin >> b[i];
    }
    
    int* result = Merger(a, b, n);
 
    for (int k = 0; k < n + n; k++) {
        cout << result[k] << ' ';
    }
    return 0;
}
память не забудь вернуть
0
0 / 0 / 0
Регистрация: 03.10.2019
Сообщений: 39
05.12.2019, 19:49  [ТС]
_stanislav Что такое size_t, объясните пожалуйста, еще такого не проходили
0
"C with Classes"
2022 / 1404 / 523
Регистрация: 16.08.2014
Сообщений: 5,885
Записей в блоге: 1
05.12.2019, 19:59
Цитата Сообщение от 7heWh1t3 Посмотреть сообщение
Что такое size_t, объясните пожалуйста, еще такого не проходили
это псевдоним для типа который может вместить теоретически самый больший индекс для массива (сделано для переносимости) https://www.viva64.com/ru/a/0050/

Добавлено через 1 минуту
Цитата Сообщение от 7heWh1t3 Посмотреть сообщение
еще такого не проходили
поменяй на int тогда, для учебных целей достаточно, а написал я так по привычке.
0
0 / 0 / 0
Регистрация: 03.10.2019
Сообщений: 39
05.12.2019, 20:27  [ТС]
_stanislav спасибо, понял
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
05.12.2019, 21:09
7heWh1t3, что Вы сравниваете ?
Цитата Сообщение от 7heWh1t3 Посмотреть сообщение
if (a[i] < b[j])
в этой задаче ничего сравнивать не нужно

Добавлено через 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
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
#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;
} 
 
int* Merger (int* a, int* b, int n)
{
    int p=0;
    int *c = new int[2*n];
 
    for (int i = 0; i < n; i++) 
    { 
        c[p++]=a[i];
        c[p++]=b[i];
    }
 
    return c;
}
 
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;
    cout << "n="; cin >> n;    
    
    int *a = new int[n];
    int *b = new int[n];
    
    Random(a,n);
    cout << "Array a:\n";
    Print(a,n);    
    
    Random(b,n);
    cout << "Array b:\n";
    Print(b,n);
    
    int* c = Merger(a,b,n);
 
    cout << "Array c:\n";
    Print(c,2*n);
    
    delete[]a;
    delete[]b;
    delete[]c;
system("pause");
return 0;
}
Добавлено через 4 минуты
можно не объявлять массив в функции, по условию в функции только слияние, тогда чуть переделать:
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
#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 Merger (int* a, int* b, int* c, int n)
{
    int p=0;    
 
    for (int i = 0; i < n; i++) 
    { 
        c[p++]=a[i];
        c[p++]=b[i];
    }    
}
 
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;
    cout << "n="; cin >> n;    
    
    int *a = new int[n];
    int *b = new int[n];
    int *c = new int[2*n];
    
    Random(a,n);
    cout << "Array a:\n";
    Print(a,n);    
    
    Random(b,n);
    cout << "Array b:\n";
    Print(b,n);
    
    Merger(a,b,c,n);
 
    cout << "Array c:\n";
    Print(c,2*n);
    
    delete[]a;
    delete[]b;
    delete[]c;
system("pause");
return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.12.2019, 21:09
Помогаю со студенческими работами здесь

Слияние массивов
Получить массив С(k), упорядоченный по возрастанию, путем слияния массивов A(n) и B(m), упорядоченных перед этим по возрастанию, где k = n...

Слияние массивов на с++
Добродень всем.задача такая:массив структур размера N(в моем случае 100).разбить на ленты.т.о получается 10 лент по 10 элементов в каждой...

Слияние 2-х одномерных массивов
всем привет Даны два одномерных массива с произвольными НО упорядоченными по возрастанию элементами написать функцию для слияния этих...

Сортировка и слияние массивов
Товарищи, помогите пожалуйста разобраться с заданием. Буду очень благодарен.

Слияние трех массивов
Помогите пожалуйста написать небольшую программку. Даны три массива A, B, C Написать программу слияния этих массивов. Убидительная...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru