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

Сформировать массив U из элементов массивов X, Y, Z

24.02.2021, 21:08. Показов 1478. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Заданы массивы целых положительных чисел X(n), Y(k), Z(m). Сформировать массив U из элементов массивов X, Y, Z, которые образуют убывающую последовательность цифр. Найти сумму семи наименьших чисел массива U.
Помогите обнаружить проблему или предложите другой вариант.
Буду весьма признателен.
Вот, что имеется:
#include <iostream>
#include <cstdlib>
#include <vector>
#include <ctime>
using namespace std;

void Random (int *a, int N)
{
for (int i = 0; i < N; i++)
a[i]=rand()%991 + 10;
}

bool IsDescent(int n)
{
int d;
while (n)
{
d=n%10;
n/=10;
if (d>=n%10 && n) return false;
}
return true;
}

int *Create(int *X, int n, int *Y, int m, int *Z, int k, int &p)
{
vector<int> temp;
for (int i = 0; i < n; i++)
if(IsDescent(X[i])) {p++;temp.push_back(X[i]);}
for (int i = 0; i < m; i++)
if(IsDescent(Y[i])) {p++;temp.push_back(Y[i]);}
for (int i = 0; i < k; i++)
if(IsDescent(Z[i])) {p++;temp.push_back(Z[i]);}

int* U=NULL;
if(p)
{

U = new int[p];

for (int i = 0; i < p; i++)
U[i]=temp[i];
}
return U;
}

void Sort(int *U, int n)
{
for (int i=0; i<n-1; i++)
for (int j=0; j<n-i-1; j++)
if (U[j] > U[j+1])
swap(U[j], U[j+1]);
}

int sum7(int *U, int b)
{
int sum=0;
for (int i = 0; i < b; i++)
sum+=U[i];
return sum;
}

void Print (int *a, int N)
{
for (int i = 0; i < N; i++)
cout << a[i] << " ";
cout << "\n";
}

int main()
{
setlocale(LC_ALL, "Russian");
srand((int)time(0));
int n, m, k, b=7, p=0;
cout<<"Введите количество эл-ов в массиве X:";
cin >> n;
cout<<"Введите количество эл-ов в массиве Y:";
cin >> m;
cout<<"Введите количество эл-ов в массиве Z:";
cin >> k;

int *X = new int[n];
int *Y = new int[m];
int *Z = new int[k];

Random(X,n);
cout<<"Массив X:"<<endl;
Print(X,n);
Random(Y,m);
cout<<"Массив Y:"<<endl;
Print(Y,m);
Random(Z,k);
cout<<"Массив Z:"<<endl;
Print(Z,k);
int *U=Create(X,n,Y,m,Z,k,p);

if(p)
{
cout<<"Массив U:"<<endl;
Print(U,p);

if (p>=7)
{
Sort(U,p);
cout<<"Рассортированный массив U:"<<endl;
Print(U,p);
cout<<"Сумма 7 эл-ов массива U:"<<sum7(U,b)<<endl;
}
}
else cout << "Такие элементы отсутсвуют";

delete[]X;
delete[]Y;
delete[]Z;
delete[]U;
system("pause");
return 0;
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.02.2021, 21:08
Ответы с готовыми решениями:

Сформировать массив из элементов исходных массивов, меньших произведения последних элементов заданных массивов.
Программа должна: 1)генерировать случайным образом элементы исходных массивов; 2)выполнять действия в соответствии с условием задачи; ...

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

Сформировать новый массив С из элементов массивов А и В по правилу
Вывести два целочисленных массива А и В одинаковой длинны и сформировать новый массив С, который состоит из элементов : {c}_{i}= max ...

1
Модератор
Эксперт CЭксперт С++
 Аватар для Volga_
5209 / 2927 / 1509
Регистрация: 14.12.2018
Сообщений: 5,267
Записей в блоге: 1
24.02.2021, 21:45
Лучший ответ Сообщение было отмечено Helpplease как решение

Решение

Цитата Сообщение от Helpplease Посмотреть сообщение
Заданы массивы целых положительных чисел X(n), Y(k), Z(m). Сформировать массив U из элементов массивов X, Y, Z, которые образуют убывающую последовательность цифр. Найти сумму семи наименьших чисел массива U.
Помогите обнаружить проблему или предложите другой вариант.
На основании вашего кода можно попробовать:
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#include <iostream>
#include <cstdlib>
#include <vector>
#include <ctime>
using namespace std;
 
void Random(int* a, int N)
{
    for (int i = 0; i < N; i++)
        a[i] = rand() % 1000;
}
 
int* CreateU(int* X, int n, int* Y, int m, int* Z, int k, int& p)
{
    vector<int> temp;
    if (n * m * k)
    {
        for (int i = 0; i < n; i++)
            temp.push_back(X[i]);
        for (int i = 0; i < m; i++)
            temp.push_back(Y[i]);
        for (int i = 0; i < k; i++)
            temp.push_back(Z[i]);
        p = m + n + k;
        int* U = new int[p];
        for (int i = 0; i < p; i++)
            U[i] = temp[i];
 
        for (int i = 0; i < p-1; i++)
            for (int j = i; j < p; j++)
            {
                int tmp;
                if (U[i] > U[j])
                {
                    tmp = U[i];
                    U[i] = U[j];
                    U[j] = tmp;
                }
            }
        return U;
    }
 
    return NULL;
}
 
int sum7(int* U)
{
    int sum = 0;
    for (int i = 0; i < 7; i++)
            sum += U[i];
    return sum;
}
 
void Print(int* a, int N)
{
    for (int i = 0; i < N; i++)
        cout << a[i] << " ";
    cout << "\n";
}
 
int main()
{
    setlocale(LC_ALL, "Russian");
    srand((int)time(0));
    int n, m, k, b = 7, p = 0;
    cout << "Введите количество эл-ов в массиве X:";
    cin >> n;
    cout << "Введите количество эл-ов в массиве Y:";
    cin >> m;
    cout << "Введите количество эл-ов в массиве Z:";
    cin >> k;
 
    int* X = new int[n];
    int* Y = new int[m];
    int* Z = new int[k];
 
    Random(X, n);
    cout << "Массив X:" << endl;
    Print(X, n);
    Random(Y, m);
    cout << "Массив Y:" << endl;
    Print(Y, m);
    Random(Z, k);
    cout << "Массив Z:" << endl;
    Print(Z, k);
    int* U = CreateU(X, n, Y, m, Z, k, p);
 
    if (p)
    {
        cout << "Массив U:" << endl;
        Print(U, p);
 
        if (p >= 7)
            cout << "Сумма 7 эл-ов массива U:" << sum7(U) << endl;
                delete[]U;
    }
    else cout << "Такие элементы отсутсвуют";
 
    delete[]X;
    delete[]Y;
    delete[]Z;
    
    system("pause");
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.02.2021, 21:45
Помогаю со студенческими работами здесь

Сформировать массив, состоящий из одинаковых элементов выходных массивов
Ввести два массива X и Y, состоящие из 10-ти элементов целого типа. Сформировать массив S, состоящая из одинаковых элементов выходных...

Сформировать массив S, состоящий из одинаковых элементов исходных массивов
2 массива X, Y, каждый из 10 эл-в. Сформировать массив S, состоящий из одинаковых эл-в исходных массивов. #include&lt;iostream&gt; ...

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

Сформировать массив из двух других массивов с исключением повторяющихся элементов
Дано 2 массива. Сформировать третий массив, включив в него все элементы, которые есть и в первом, и во втором массиве. Повторяющиеся...

Сформировать массив со значениями максимума соответствующих элементов двух других массивов
Реализовать на C++ Как это сделать? ( Даны два массива А и В одинакового размера N. Сформировать новый массив С того же размера,...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru