С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 Аватар для SaynorPRO
11 / 11 / 5
Регистрация: 05.10.2016
Сообщений: 122

Наидлиннейшая возрастающая подпоследовательность

27.05.2017, 22:21. Показов 512. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дана какая-то последовательность, в ней нужно найти самую длинную возрастающую подпоследовательность.

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

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
//INFORMATICS
#include <iostream>
#include <vector>
#include <iterator>
 
using namespace std;
 
 
int main() {
  int n;
  cin >> n;
  vector<int> a(n + 1, 0), d(n, 0), p(n, 0);
  d[0] = 1;
  p[0] = -1;
  for (int i = 0; i < n; i++) {
    cin >> a[i];
  }
  int maxElement = 0;
  for (int i = 1; i < n; i++) {
    d[i] = 1;
    p[i] = -1;
    int maxx = n;
    for (int j = 0; j < i; j++) {
      if (a[j] >= a[maxx] && a[j] < a[i]) {
        maxx = j;
        d[i] = d[maxx] + 1;
        p[i] = maxx;
      }
    }
    if (d[maxElement] < d[i]) {
      maxElement = i;
    }
  }
  vector<int> path;
  path.push_back(a[maxElement]);
  cout << d[maxElement] << endl;
  while (p[maxElement] != -1) {
    path.push_back(a[p[maxElement]]);
    maxElement = p[maxElement];
  }
  copy(path.rbegin(), path.rend(), ostream_iterator<int>(cout, " "));
  return 0;
}
Добавлено через 15 минут
Проблема решена, ошибка была в 24 строке:
C++
1
if (a[j] >= a[maxx] && a[j] < a[i])
Исправленный код:
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
//INFORMATICS
#include <iostream>
#include <vector>
#include <iterator>
 
using namespace std;
 
 
int main() {
  int n;
  cin >> n;
  vector<int> a(n, 0), d(n + 1, 0), p(n, 0);
  d[0] = 1;
  p[0] = -1;
  for (int i = 0; i < n; i++) {
    cin >> a[i];
  }
  int maxElement = 0;
  for (int i = 1; i < n; i++) {
    d[i] = 1;
    p[i] = -1;
    int maxx = n;
    for (int j = 0; j < i; j++) {
      if (d[j] > d[maxx] && a[j] < a[i]) {
        maxx = j;
        d[i] = d[maxx] + 1;
        p[i] = maxx;
      }
    }
    if (d[maxElement] < d[i]) {
      maxElement = i;
    }
  }
  vector<int> path;
  path.push_back(a[maxElement]);
  cout << d[maxElement] << endl;
  while (p[maxElement] != -1) {
    path.push_back(a[p[maxElement]]);
    maxElement = p[maxElement];
  }
  copy(path.rbegin(), path.rend(), ostream_iterator<int>(cout, " "));
  return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.05.2017, 22:21
Ответы с готовыми решениями:

НВП (наибольшее возрастающая подпоследовательность)
Всем привет. Сегодня наткнулся на задачу в которой нужно найти НВП за O(n * log (n)) где n - длина массифа. Не могли бы вы объяснить мне...

Строго возрастающая макс. подпоследовательность
Долго ломал голову над задачей. Наконец-то нашел код (он правда, на паскале). Переделал, все хорошо. Но вот не задача: никак не могу...

Наибольшая возрастающая подпоследовательность за O(NlogN)
Здравствуйте! Вот тут написал код НВП за О(NlogN).Но на тестирующей системе он выдает на тесты некоторые неправильные ответы.Тестов я...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.05.2017, 22:21
Помогаю со студенческими работами здесь

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

Динамическое программирование: самая длинная строго возрастающая подпоследовательность
Здравствуйте!!! У меня есть такое задание: дана последовательность целых чисел. Необходимо найти её самую длинную строго возрастающую...

Наидлиннейшая общая подпоследовательность
Как оптимизировать алгоритм если на вход даются 2 строки длина каждой из которых не больше 1000000 ? Создавать таблицу и выделять память...

Наибольшая возрастающая подпоследовательность
Дна последовательность, нужно найти её наибольшую возрастающую подпоследовательность. Входные данные: N- длина...

Наибольшая возрастающая подпоследовательность
program true2; {$APPTYPE CONSOLE} uses SysUtils; const n=5; plusinf=88; minusinf=-88;


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый 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 —. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru