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

Является ли вторая последовательность подпоследовательностью первой?

11.12.2019, 01:00. Показов 3179. Ответов 1

Студворк — интернет-сервис помощи студентам
Доброе время суток!
Пожалуйста, подскажите как написать данную программу, вот условие:
Даны две последовательности x[1] . . x[n] и y[1] . . y[k] целых чисел. Выяснить, является ли вторая последовательность подпоследовательностью первой, т. е. можно ли из первой вычеркнуть некоторые члены так, чтобы осталась вторая.

Понимаю, что не хватает строк, чтобы выводило надпись "Является последовательность" или "Не является последовательностью" и то что получилось с последовательностью, после того как удалили элемент. А вот как это сделать не знаю.
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
#include "stdafx.h"
#include<iostream>
#include <algorithm>
#include <cstdlib>
#include <ctime>
 
void main()
{
    using namespace std;
    setlocale(LC_ALL, "rus");
    const int K = 100;
    int i, sA, sB, A[K], B[K];
    cout << "Введите размер массива A: ";
    cin >> sA;
    cout << "ВВедите размер массива В: ";
    cin >> sB;
    cout << "Массив А:" << endl;
    srand(time(0));
    for (i = 0; i < sA; i++)
    {
        A[i] = rand() % 10;
        cout << A[i] << " ";
    }
    cout << endl;
    cout << "Массив В: " << endl;
    for (i = 0; i < sB; i++)
    {
        B[i] = rand() % 10;
        cout << B[i] << " ";
    }
    cout << endl;
    for (i = 0; i < sA; i++)
    {
        if (A[i] != B[i])
        {
            cout << A[i] << " ";
        }
        else
        {
            cout << B[i] << " ";
        }
    }
    cout << endl;
    system("pause");
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.12.2019, 01:00
Ответы с готовыми решениями:

Даны две последовательности , выяснить,является ли вторая последовательность подпоследовательностью первой
Вот такая задача : даны две последовательности x . . x и y . . y целых чисел. Выяснить, является ли вторая последовательность...

Выяснить, является ли одна последовательность подпоследовательностью другой
Доброго времени суток дорогие друзья,уже в каторый раз я постараюсь попросить у вас помощи,полазил в интернете и маловато адекватного...

Определить, является ли последовательность массива b подпоследовательностью массива a
дан массив a и массив b, n&gt;=m. нужно определить является ли последовательность массива b подпоследовательностью массива a. Написал...

1
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
11.12.2019, 02:02
Лучший ответ Сообщение было отмечено homa_03 как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
 
bool is_subarray(const int* buf, size_t buf_cnt, const int* subbuf, size_t subbuf_cnt) {
    return *buf == *subbuf && (subbuf_cnt == 0 || is_subarray(buf + 1, buf_cnt-1, subbuf + 1, subbuf_cnt-1))
        || buf_cnt && is_subarray(buf + 1, buf_cnt-1, subbuf, subbuf_cnt);
}
int main() {
    int sequence[] = {1, 20, 34, 2, 344, 45, 3};
    int subsequence[] = { 1, 2, 3};
    std::cout << (
        is_subarray(sequence, std::size(sequence), subsequence, std::size(subsequence)) 
        ? "substring" : "not substring"
        ) << std::endl;
    return 0;
}
Добавлено через 8 минут
Впрочем, раз уж ты пользуешься библиотечными решениями вместо своего алгоритма и раз уж тебе можно подключать
C++
1
#include <algorithm>
Раз уж так, то пиши тогда сразу
C++
1
2
3
4
5
6
    sort(begin(sequence), end(sequence));
    sort(begin(subsequence), end(subsequence));
    cout << (
        includes(begin(sequence), end(sequence), begin(subsequence), end(subsequence))
        ? "substring" : "not substring"
        ) << endl;
но это уже будет не твой алгоритм, а библиотечный и за задание может не быть зачтён
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.12.2019, 02:02
Помогаю со студенческими работами здесь

Проверить, является ли вторая строка аббревиатурой первой
Дано две строки. Первая содержит слова, разделенные одним или несколькими пробелами или спец символами. Вторая строка содержит...

Выяснить, является ли вторая последовательность подпоследовательностью первой
Добрый день, уважаемые форумчане. С# изучаю совсем недавно, недавно получил такое задание, пока даже не знаю, как подобраться. Помогите,...

Выяснить, является ли вторая последовательность последовательностью первой
Задание.2 Даны две последовательности целых чисел a0,.....,an и b0,.....,bm выяснить является ли вторая последовательность...

Является ли вторая перестановка обратной первой
Выводит данную ошибку при выполнение условия (writeln('YES')): Program1.pas(14) : Ошибка времени выполнения: Индекс находился вне границ...

Проверить является ли массив В подпоследовательностью массива А
Доброго времени суток всем пользователям форума.Завтра мой последний шанс получить допуск к зачету.Не получается решить вот эти две задачи...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
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