Форум программистов, компьютерный форум CyberForum.ru

Рекурсия: найти подпоследовательность подряд идущих элементов последовательности, сумма которых минимальна - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Ошибка: "case expression not constant" http://www.cyberforum.ru/cpp-beginners/thread71147.html
int draw(char form, int razmer){ switch(form){ case"t":{ int i=0; while(i<=10) { int s=10;
C++ указатели помогите решить ипользуя указатели 1. Измените порядок следования элементов в массиве так, чтобы сначала располагались все отрицательные элементы, потом нулевые, затем положительные элементы. 2. Найти наименьший элемент среди нечетных столбцов матрицы. http://www.cyberforum.ru/cpp-beginners/thread71146.html
C++ Поиск букв в тексте
Добрый вечер! Очень надеюсь на вашу помощь, у самого никак не получаеться решить следущую задачку для C++ "Распечатать в порядке, обратном алфавитному, все буквы, которые входят в текст не менее трех раз."
C++ функция для принта
есть ли такая функция с помощью которой выводится на принетр некоторое значение?
C++ Обращение к методам объекта по ссылке на объект http://www.cyberforum.ru/cpp-beginners/thread71119.html
Метод объекта возвращает значение одного из параметров объекта. Необходимо обратиться к методу объекта по ссылке на этот объект. Когда обращаюсь к параметру объекта по ссылке на объект - все нормально Но метод при обращении по ссылке на объект работает некорректно. Почему? #include <conio.h> #include <stdio.h> class cl_object
C++ Печать значений элементарных функций по формуле Тейлора! http://i043.***********/0912/82/fa0b56f41821.jpg Помогите пожалуйста закодить,ну или хотя бы придумать алгоритм для этой задачи. Объясните еще что значит интервал от а до б,это все значения,которые можт принимать х? Вообще,мне кажется,программа оч простая,просто я само задание пока не оч понял,вы не видели нашего учителя по матану,если бы увидели,не стали бы меня винить в непонимании, а... подробнее

Показать сообщение отдельно
valeriikozlov
Эксперт C++
4669 / 2495 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
07.12.2009, 08:34     Рекурсия: найти подпоследовательность подряд идущих элементов последовательности, сумма которых минимальна
для длины подпоследовательности от 2-х и более элементов, сумма которых минимальна:
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
#include <iostream.h>
#include <windows.h>
#include<conio.h>
 
void posl_min(int *mas, int n, int i, int &i_start, int &count, int count_temp, bool fl, bool &fl1)
{
    if(mas[i]==mas[i+1])
    {
        if(fl)
        {
            count_temp++;
        }
        if(!fl)
        {
            fl=true;
            count_temp=2;
        }       
    }
    if((mas[i]!=mas[i+1] || i==n-2) && fl)
    {
        if(!fl1)
        {
            fl1=true;
            i_start=i-count_temp+1;
            count=count_temp;
        }
        if(mas[i]*count_temp<count*mas[i_start] && fl1)
        {
            i_start=i-count_temp+1;
            count=count_temp;
        }
        if(i==n-2 && fl)
            i_start++;
        fl=false;
    }
    i++;
    if(i<n-1)
        posl_min(mas, n, i, i_start, count, count_temp, fl, fl1);
}   
 
 
void main()
{
    int *mas, n, i=0, i_start=0, count=0, count_temp;
    bool fl=false, fl1=false;
    SetConsoleCP(1251);
    SetConsoleOutputCP(1251);
    cout<<"Ââåäèòå Г°Г*çìåðГ*îñòü ïîñëåäîâГ*òåëüГ*îñòè: "<< endl;
    cin>>n;
    mas=new int[n];
    cout<<"Ââåäèòå ýëåìåГ*ГІГ» ïîñëåäîâГ*òåëüГ*îñòè: "<< endl;
    for(i=0; i<n; i++)
    {
       cout<<"["<<i<<"]= ";
       cin>>mas[i];
    }
    cout<<"èñõîäГ*Г*Гї ïîñëåäîâГ*òåëüГ*îñòü:"<<endl;
    for(i=0; i<n; i++)
       cout<<mas[i]<<" ";
    cout<<endl;
    i=0;
    posl_min(mas, n, i, i_start, count, count_temp=0, fl, fl1);
    if(!fl1)
        cout<<"Ïîäðÿä èäóùèõ ýëåìåГ*òîâ Г*ГҐГІ";
    else
    {
        cout<<"Ïîäðÿä èäóùèå ýëåìåГ*ГІГ» Г± ìèГ*ГЁГ¬Г*ëüГ*îé ñóììîé: "<<endl;
        for(i=i_start; i<i_start+count; i++)
            cout<<mas[i]<<" ";
    }
    cout<<endl;
    getch();
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru