Форум программистов, компьютерный форум, киберфорум
Наши страницы
C# для начинающих
Войти
Регистрация
Восстановить пароль
 
ellaktozar
0 / 0 / 0
Регистрация: 23.10.2017
Сообщений: 2
1

Задача о неубывающей подпоследовательности

23.10.2017, 23:38. Просмотров 135. Ответов 2
Метки нет (Все метки)

Всем форумчанам доброго времени суток, я пытаюсь реализовать задачу, суть её такова, нам дано количество чисел в последовательности, и сама последовательность чисел. Нужно вычеркнуть оттуда минимальное количество чисел, чтобы получилась наибольшая подпоследовательность. Я написал код, который работает на некоторых тестах, однако если последовательность например { 9 4 1 1 7 9 6 10 2 3 }, то почему-то выводится { 9 1 1 7 9 10 }, собственно слезно прошу помочь в поиске ошибок.

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
using System;
using System.IO;
using System.Linq;
 
namespace posledovatelnost
{
    class Program
    {
        static void print(ref long[] arr, ref int[] arr2, int index, StreamWriter write, bool first)
        {
                if (index != -1)
                {
                    int i = index;
                    index = arr2[index];
                    print(ref arr, ref arr2, index, write, false);
                    if (first)
                    {
                        write.WriteLine(arr[i]);
                    }
                    else
                    {
                        write.Write(arr[i] + " ");
                    }
                }
        }
        static void Main(string[] args)
        {
            string s;
            using (StreamReader read = new StreamReader("input.txt"))
            {
                s = read.ReadToEnd();
            }
            long[] nums = s
                         .Split(new char[] { ' ', '\n', '\r' }, StringSplitOptions.RemoveEmptyEntries)
                         .Select(t => long.Parse(t))
                         .ToArray();
            long n = nums[0];
            long[] posl = new long[n];
            for (int i = 1; i <= n; i++)
            {
                posl[i - 1] = nums[i];
            }
            int[] length = new int[n];
            int[] preIndex = new int[n];
            preIndex[0] = -1;
            length[0] = 1;
            int max = 1, index = 0;
            for (int i = 1; i < n; i++)
            {
                length[i] = 0;
            }
            for (int i = 1; i < n; i++)
            {
                for (int j = 0; j < i; j++)
                {
                    if (posl[j] <= posl[i] && length[i] <= length[j] + 1)
                    {
                        preIndex[i] = j;
                        length[i] = length[j] + 1;
                        if (length[i] > max)
                        {
                            max = length[i];
                            index = i;
                        }
                    }
                }
            }
            using (StreamWriter write = new StreamWriter(new FileStream("output.txt", FileMode.Append)))
            {
                write.WriteLine(max);
                print(ref posl, ref preIndex, index, write, true);
            }
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.10.2017, 23:38
Ответы с готовыми решениями:

Подпоследовательности С#
Помогите решить задачу. Дан массив: {xi}, i = 1...n. Найти номера начального и конечного...

Код подпоследовательности
Товарищи, помогите пожалуйста, кто может написать программу(как вы поняли на языке с#)тест на ...

Образовать из неубывающих последовательностей новую последовательность так, чтобы она тоже была неубывающей
Даны две последовательности a_1 ≤ a_(2 )… ≤ a_(n ) и〖 b〗_1 ≤ b_(2 )… ≤ b_(m ). Образовать из них...

Определить количество чисел в наиболее длинной подпоследовательности
Дана последовательность из 100 целых чисел. Определить количество чисел в наиболее длинной...

Поиск самой длинной неубывающей подпоследовательности
Формулировка задачи: Реализовать на языке C или C++ алгоритм поиска для заданной числовой...

2
Aael
394 / 296 / 170
Регистрация: 02.06.2016
Сообщений: 514
Завершенные тесты: 1
24.10.2017, 01:01 2
ellaktozar,
C#
1
2
3
4
5
6
7
8
9
10
int[] length = new int[n];
int[] preIndex = new int[n];
//preIndex[0] = -1;
//length[0] = 1;
int max = 1, index = 0;
for (int i = 1; i < n; i++)
{
    length[i] = 1; // у всех длина равна единице, т.к. путь включает саму вершину
    preIndex[i] = -1; // ни у одной вершины пока нет предыдущих
}
1
ellaktozar
0 / 0 / 0
Регистрация: 23.10.2017
Сообщений: 2
24.10.2017, 01:12  [ТС] 3
Всё прекрасно работает, сердечно благодарю
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.10.2017, 01:12

Поиск самой длинной неубывающей подпоследовательности
Формулировка задачи: Реализовать на языке C или C++ алгоритм поиска для заданной числовой...

Функция нахождения самой длинной неубывающей подпоследовательности
Помогите найти ошибку //Функция находит самую длинную неубывающую подпоследовательность void...

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


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru