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

Поиск подпоследовательностей в массиве

28.03.2016, 19:33. Показов 2975. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Надо найти все подпоследовательности в массиве.
Например: массив: {3,4,1,2}, подпоследовательности: {3},{4},{1},{2},{3,4,1},{4,1,2},{3,4},{4 ,1},{1,2}
Использовать можно только стандартные библиотеки.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.03.2016, 19:33
Ответы с готовыми решениями:

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

Элементы, которые присутствуют в массиве А, но отсутствуют в массиве В (сортировка - выбором, поиск - двоичный)
элементы, которые присутствуют в массиве А, но отсутствуют в массиве В алгоритм сортировки:Выбором Алгоритм поиска: двоичный Сделать...

В одномерном массиве состоящем из n вещественных элементов сделать бинарный поиск числа А в упорядоченном массиве
Всем привет помогите решить задачи 1) В одномерном массиве состоящем из n вещественных элементов: сделать бинарный поиск числа А в...

6
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
28.03.2016, 22:33
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
 
int main(int, char**) {
  int x[] = {3,4,1,2};
  int size = sizeof(x) / sizeof(x[0]);
  
  for (int i = 1; i < size; ++i) {
    for (int j = 0; j < size - i + 1; ++j) {
      std::cout << "{";
      for (int k = 0; k < i; ++k) {
        std::cout << x[j + k] << (k < (i - 1) ? ", " : "");
      }
      std::cout << "}" << std::endl;
    }
  }
}
1
0 / 0 / 0
Регистрация: 28.03.2016
Сообщений: 4
29.03.2016, 10:55  [ТС]
lemegeton
Спасибо, но я уше сам справился, только немного по другому)
Теперь у меня другая проблема, программа выполняется на 0.09 секунд больше, чем надо, не подскажешь, что можно сделать?
0
28 / 20 / 97
Регистрация: 22.10.2015
Сообщений: 304
29.03.2016, 11:01
denismartynov, ну дык покажи как ты сделал
0
0 / 0 / 0
Регистрация: 28.03.2016
Сообщений: 4
29.03.2016, 11:08  [ТС]
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include <iostream>
#include <stdio.h>
 
using namespace std;
 
int main()
{
    long long int sum(0);
    int n;
    scanf("%d", &n);
    long long int *arr = new long long int[n];
    if (n<1 || n>10000) return 0;
    for (int i(0); i < n; i++)
    {
        scanf("%d", &arr[i]);
        if (arr[i] < 1 || arr[i] > 1000000000) return 0;
        sum += arr[i];
    }
    if (n == 1){ sum = arr[0]; }
    if (n == 2){
        sum = arr[0] + arr[1];
        if (arr[0] >= arr[1]){ sum += arr[1]; }
        else{ sum += arr[0]; }
    }
    int min;
    min = 0;
    int j = 0, m = n-1;
    start:
    if (n >= 3)
    {
            if (m == (j + 1))
            {
                min = arr[j];
                for (int p = j; p <= m; p++)
                {
                    if (min > arr[p])
                    {
                        min = arr[p];
                    }
                }
                sum += min;
                goto stop1;
            }
            min = arr[j];
            for (int y = j; y <= m; y++)
            {
                if (min > arr[y])
                {
                    min = arr[y];
                }
            }
            sum += min;
            goto stop;
        
    }
    
    stop:
    for (int c = j+1; c < m; c++)
    {
        
        min = arr[c];
        for (int f = c; f <= m; f++)
        {
            if (min>arr[f])
            {
                min = arr[f];
            }
        }
        sum += min;
    }
    for (int u = m-1; u > j; u--)
    {
        min = arr[u];
        for (int f = u; f >= j; f--)
        {
            if (min>arr[f])
            {
                min = arr[f];
            }
        }
        sum += min;
    }
    if ((j + 1) < (m-1)) 
    {
        j++; m--;
        goto start;
    }
 
    stop1:
    cout << sum;
 
    return 0;
}
Условие такое: нужно было найти все подпоследовательности в массиве и в этих подпоследовательностях найти минимальное число, и сложить все эти минимальные числа
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
29.03.2016, 15:20
Простите, я совсем не понимаю, что делает ваш код.

Мое решение за n^3:
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 main(int, char**) {
  int x[] = {3,4,1,2};
  int size = sizeof(x) / sizeof(x[0]);
  int sumOfMins = 0;
  
  for (int i = 1; i < size; ++i) {
    for (int j = 0; j < size - i + 1; ++j) {
      int min = x[j];
      std::cout << "{";
      // тут можно чуть-чуть срезать и начать считать от k = 1, но тогда вывод надо убрать
      for (int k = 0; k < i; ++k) {
        std::cout << x[j + k] << (k < (i - 1) ? ", " : "");
        if (min > x[j + k]) {
          min = x[j + k];
        }
      }
      std::cout << "}, min = " << min << std::endl;
      sumOfMins += min;
    }
  }
  std::cout << "Sum of mins = " << sumOfMins << std::endl;
}
0
0 / 0 / 0
Регистрация: 28.03.2016
Сообщений: 4
29.03.2016, 19:11  [ТС]
Спасибо большое, я долго думал, над этой программой, но придумал только таким способом)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.03.2016, 19:11
Помогаю со студенческими работами здесь

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

Поиск заданного элемента в упорядоченном массиве(бинарный поиск)
Заполнить одномерный массив из n элементов по формуле приведенной в картинке. Размерность массива задать в виде именованной константы....

Поиск заданного элемента в упорядоченном массиве (бинарный поиск)
Заполнить одномерный массив из n элементов согласно таблицы. Размерность массива задать в виде именованной константы. Вывести массив на...

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

Поиск числа в двумерном массиве (бинарный поиск)
Произвожу поиск элемента в массиве двумя способами: линейным(последовательным) поиском и бинарным(двоичным). Первый работает на ура. Второй...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru