С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/55: Рейтинг темы: голосов - 55, средняя оценка - 4.67
 Аватар для Kolbusdkiy
0 / 0 / 1
Регистрация: 14.10.2013
Сообщений: 112

Найдите количество ее возрастающих подпоследовательностей

05.04.2014, 10:46. Показов 11358. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задана последовательность целых чисел.

Найдите количество ее возрастающих подпоследовательностей
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.04.2014, 10:46
Ответы с готовыми решениями:

Найти минимум среди максимумов всех возрастающих подпоследовательностей
Сама задача полностью В потоке ввода данных записана последовательность целых чисел, последнее из которых 0. Найти минимум среди...

Разбить числовой список на подсписки из возрастающих подпоследовательностей
Приветствую! Подскажите, пожалуйста, как на Haskell красиво решить вот такую задачу: Заданный числовой список разбить на...

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

8
Модератор
Эксперт С++
 Аватар для zss
13770 / 10963 / 6491
Регистрация: 18.12.2011
Сообщений: 29,240
05.04.2014, 16:55
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
const int N=100;
int A[N];
// ... заполняем массив
int amount=0;
bool vozr=false;
for(int i=1;i<N;i++)
{
    if(A[i]>A[i-1])
        vozr=true; //Нашлась возрастающая последовательность
    else
    {
        if(vozr)
        {
              vozr=false;//Кончилась возрастающая последовательность
              amount++; // сосчитали ее
        }
    }
}
if(vozr)
     amount++; // сосчитали последнюю в конце
cout<<amount;
1
1406 / 648 / 135
Регистрация: 11.08.2011
Сообщений: 2,299
Записей в блоге: 2
05.04.2014, 17:00
Цитата Сообщение от Kolbusdkiy Посмотреть сообщение
подпоследовательностей
Скорее всего имеется ввиду: подпоследовательность - последовательность, которая получается вычеркиванием некоторых элементов из исходной последовательности.
0
Day
 Аватар для Day
1180 / 990 / 83
Регистрация: 29.10.2009
Сообщений: 1,385
05.04.2014, 17:20
Цитата Сообщение от Kolbusdkiy Посмотреть сообщение
Найдите количество ее возрастающих подпоследовательностей
Что имеется в виду под "подпоследовательностью"? Отрезкивида a[2], a[3], a[4]? Тогда решение предложенное zss, похоже на правду (в детали не лез). Или классическое (из матана) определение? Там a[1], a[3], a[7] тоже считается подпоследовательностью. Тогда все будет несколько посложнее.
Еще вопрос. Считать ли последовательность из одного элемента возрастающей подпоследовательностью? Ибо формально это так. Однако, постановщик задачи вправе их не учитывать, специально оговорив.

Добавлено через 42 секунды
Цитата Сообщение от Dani Посмотреть сообщение
Скорее всего имеется ввиду: подпоследовательность - последовательность, которая получается вычеркиванием некоторых элементов из исходной последовательности.
Вот-вот. Именно это я и имел в виду.

Добавлено через 8 минут
zss, в преположении, что нас интересуют только отрезки длины больше 1, ваш код можно несколько упростить...
C++
1
2
3
for(int i=0;i<N-1;i++) {
    if(A[i+1]>A[i]) amount ++;
}
0
Модератор
Эксперт С++
 Аватар для zss
13770 / 10963 / 6491
Регистрация: 18.12.2011
Сообщений: 29,240
05.04.2014, 17:24
Цитата Сообщение от Day Посмотреть сообщение
if(A[i+1]>A[i]) amount ++;
Не пойдет, т.к. каждая пара будут считаться подпоследовательностью.
Надо отследить начало и конец каждой пп.
0
1406 / 648 / 135
Регистрация: 11.08.2011
Сообщений: 2,299
Записей в блоге: 2
05.04.2014, 17:31
zss, если есть последовательность 1 2 3 4 5. Чем 1 2 3 или 2 3 не возрастающая?
0
Day
 Аватар для Day
1180 / 990 / 83
Регистрация: 29.10.2009
Сообщений: 1,385
05.04.2014, 17:53
Цитата Сообщение от zss Посмотреть сообщение
Не пойдет,
Пожалуй, вы правы. Погорячился. Для исходной 1 2 3 есть 3 возрастающих: 1 2, 1 2 3, 2 3. А у меня получается только 2
C++
1
2
3
4
5
6
7
for(int i=0;i<N-1;i++) {
    if(A[i+1]>A[i]) amount ++;
    for(j=i+1; j<N-1; j++) {
      if (A[j+1] > A[j]) amount++;
      else break;
    }
}
0
1406 / 648 / 135
Регистрация: 11.08.2011
Сообщений: 2,299
Записей в блоге: 2
05.04.2014, 18:01
Цитата Сообщение от Day Посмотреть сообщение
Вот-вот. Именно это я и имел в виду.
Если будет такое значение подпоследовательности, то их будет тьма. И тогда эту задачу лучше всего решать динамикой.
0
Модератор
Эксперт С++
 Аватар для zss
13770 / 10963 / 6491
Регистрация: 18.12.2011
Сообщений: 29,240
05.04.2014, 21:36
Цитата Сообщение от Day Посмотреть сообщение
1 2 3
Это одна подпоследовательность 1 - ее начало, 3 - ее конец
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.04.2014, 21:36
Помогаю со студенческими работами здесь

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

Найти количество непрерывно возрастающих серий в массиве
Добрый день. Уже который день мучаюсь над решением задачи: В одномерном массиве нужно найти кол - во непрерывно возрастающих серий. :mda:...

Найти наименьшее количество строго возрастающих участков в массиве
Мне надо написать код пожалуйста. я уже все перепробовал не получается. мне его надо отправить на кон тестер.

Даны два возрастающих массива x[k] и y[l]. Найти количество общих элементов
Даны два возрастающих массива x и y. Найти количество общих элементов в этих массивах ( т. е. количество тех ...

Вывести количество возрастающих последовательностей в массиве, а также длину самой длинной из них
Помогите пожалуйста! Написать программу, в которой пользователь вводит элементы целочисленного массива с клавиатуры. Необходимо...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru