С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
0 / 0 / 0
Регистрация: 25.12.2018
Сообщений: 22
1

Найти одно из чисел, которое содержится во всех массивах x, y и z

08.05.2019, 15:41. Показов 2188. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Помогите пожалуйста решить задачу по теме «Одномерные массивы»

Некоторое число содержится в каждом из трех целочисленных неубывающих массивов х[1] ≤ ... ≤х[р], у[1] ≤ ... ≤ у[q], z[1] ≤ ... ≤ z[r]. Найти одно из таких чисел. Число действий должно быть порядка р + q + r.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.05.2019, 15:41
Ответы с готовыми решениями:

Найти одно из чисел, которое содержится во всех массивах x, y и z
Помогите пожалуйста решить задачу по теме «Одномерные массивы» Некоторое число содержится в...

Задано два массива чисел. Определите, сколько цифр содержится в обоих массивах
3. Задано два массива чисел. Определите, сколько цифр содержится в обоих массивах

Найти последовательность максимальной длины, которая содержится в обоих массивах
Подскажите алгоритм решения задачи, а программу напишу я уже сам. Задача: Даны два массива....

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

2
6340 / 3511 / 1427
Регистрация: 07.02.2019
Сообщений: 8,977
08.05.2019, 16:11 2
Лучший ответ Сообщение было отмечено alivka как решение

Решение

alivka,
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
#include <iostream>
 
int* foo(int* bx, int* ex, int* by, int* ey, int* bz, int* ez)
{
    while (true)
    {
        while (bx != ex && *bx < *by) ++bx;
        if (bx == ex) return 0;
        while (by != ey && *by < *bz) ++by;
        if (by == ey) return 0;
        while (bz != ez && *bz < *bx) ++bz;
        if (bz == ez) return 0;
        if (*bx == *by && *bx == *bz) return bx;
    }
}
 
int main()
{
    int x[]{ 3, 3, 5, 7 };
    int y[]{ 3, 5, 6, 7, 8 };
    int z[]{ 1, 2, 4, 4, 5, 6 };
    int* res = foo(std::begin(x), std::end(x), std::begin(y), std::end(y), std::begin(z), std::end(z));
    if (res) std::cout << *res;
}
1
0 / 0 / 0
Регистрация: 25.12.2018
Сообщений: 22
10.05.2019, 18:16  [ТС] 3
А можно поподробней с функции,а то не совсем понимаю как она работает,пожалуйста?
0
10.05.2019, 18:16
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.05.2019, 18:16
Помогаю со студенческими работами здесь

Определить, содержится ли в заданной последовательности целых чисел хотя бы одно число Фибоначчи
Помогите написать) 3. задача. Определить, содержится ли в заданной последовательности целых...

Найти хотя бы одно совпадение в двух массивах
Всем привет! Имеется следующий вопрос: Есть 2 заполненных массива (mass1 и mass2). Нужно...

Найти все пары чисел в интервале, одно из которых равно сумме всех делителей другого, кроме самого числа
переведите пожалуйста код из Pascal в С++ i,j: integer; a,b: integer; //суммы делителей чисел ...

Посчитать сумму всех чисел в массивах
Помогите, пожалуйста, посчитать сумму всех полученных в цикле Ext и Eyt, сам все никак не могу...

Записать условие, которое является истинной, когда только одно из чисел А, В и С меньше 50
Записать условие, которое является истинной, когда только одно из чисел А, В и С меньше 50. ...

Записать условие, которое является истинным, когда только одно из чисел X и Y меньше 20
оператор сравнения &lt;=2 . Нельзя использовать + - / * операторы. Задача просто ломает меня второй...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru