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

Нахождение самой длинной (убывающей или возрастающей) последовательности цифр

06.11.2015, 01:35. Показов 1213. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте) Сижу здесь ламаю голову по-поводу одной задачки, в универе задали, уже все нервы вымотала. Короче алгоритм по нахождению самой длинной последовательности цифр, (убывающей или возрастающей). Код даже вроде бы я написал и работает он хорошо но к сожалению преподаватель находит какие то данные на которых он не работает по=этому я был бы очень благодарен если бы вы может мне указали на мои ошибки или дали такие данные при которых оно не работает.
Основное задание заключается вот в чем:
1)Ввод: натуральные числа (до 10^7 штук) с предела (0;10^9) разделенные пробелом и все это должно заканчиваться знаком конца строки(EOF).
2)Вывод: 2 числа разделенные пробелом 1-ое: количество цифр в самой длинной последовательности, 2-ое: сума этих чисел.

Короче пример:
ввод: 8 4 2 3 2
вывод: 3 14 //потому что самая длинная последовательность это 8 4 2 и их сума = 14

Еще для сравнения преподаватель предоставил примеры:
Ввод: 1 1 7 3 2 0 0 4 5 5 6 2 1
Вывод: 6 20

И еще пример:
Ввод: 65 87 47 5 12 74 25 32 78 44 40 77 85 4 29 57 55 79 31 63 84 66 62 41 52 36 82 86 6 98 63 65 14 57 75 14 74 15 41 88 27 75 6 78 98 78 22 77 68 74 92 47 30 44 40 52 70 66 17 60 47 97 34 37 23 69 56 57 3 45 7 76 18 35 24 73 47 77 1 84 92 54 18 98 84 36 66 71 92 13 77 28 75 24 46 67 4 63 82 1
Вывод: 4 253

Прошу прощения за переменные на польском языке) учусь именно там)

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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
#include <stdio.h>
 
#define gc getchar
 
 
inline int scan_integer();
 
 
int main()
{
    bool rosnie = true;
 
    int poprzednia;
    int terazniejsza;
 
 
    poprzednia = scan_integer();
 
    int sumaAktualnego = poprzednia;
    int sumaNajwiekszego = poprzednia;
 
    int iloscAktualnego = 1;
    int iloscNajwiekszego = 0;
 
    int staly = 1;
    int sumaStalego = 0;
 
    int i = 0;
 
    while ((terazniejsza = scan_integer()) != EOF)
    {
 
 
        if (i == 0){
            if (terazniejsza == poprzednia){
                sumaAktualnego += terazniejsza;
                iloscAktualnego++;
            }
            else if (terazniejsza < poprzednia){
                iloscAktualnego++;
                sumaAktualnego += terazniejsza;
                rosnie = false;
                i++;
            }
            else {
                iloscAktualnego++;
                sumaAktualnego += terazniejsza;
                rosnie = true;
                i++;
            }
        }
        else if (terazniejsza<poprzednia){
            if (rosnie){
                if (iloscAktualnego>iloscNajwiekszego){
                    iloscNajwiekszego = iloscAktualnego;
                    sumaNajwiekszego = sumaAktualnego;
                }
                iloscAktualnego = 2;
                sumaAktualnego = terazniejsza + poprzednia;
 
                if (staly>1){
                    iloscAktualnego += staly;
                    iloscAktualnego--;
                    sumaAktualnego += sumaStalego;
                    sumaAktualnego -= poprzednia;
                    staly = 1;
                    sumaStalego = 0;
                }
 
                rosnie = false;
            }
            else{
                sumaAktualnego += terazniejsza;
                iloscAktualnego++;
            }
        }
        else if (terazniejsza>poprzednia){
            if (rosnie){
                sumaAktualnego += terazniejsza;
                iloscAktualnego++;
            }
            else{
                if (iloscAktualnego>iloscNajwiekszego){
                    iloscNajwiekszego = iloscAktualnego;
                    sumaNajwiekszego = sumaAktualnego;
                }
                iloscAktualnego = 1;
                sumaAktualnego = terazniejsza + poprzednia;
 
                if (staly>1){
                    iloscAktualnego += staly;
                    sumaAktualnego += sumaStalego;
                    sumaAktualnego -= poprzednia;
                    staly = 1;
                    sumaStalego = 0;
                }
 
                rosnie = true;
            }
        }
        else if (terazniejsza == poprzednia){
            if (staly == 1)
                sumaStalego += poprzednia;
            staly++;
            sumaStalego += terazniejsza;
            sumaAktualnego += terazniejsza;
            iloscAktualnego++;
        }
 
        poprzednia = terazniejsza;
    }
    if (iloscAktualnego>iloscNajwiekszego){
        iloscNajwiekszego = iloscAktualnego;
        sumaNajwiekszego = sumaAktualnego;
    }
 
    printf("%d %d", iloscNajwiekszego, sumaNajwiekszego);
}
 
inline int scan_integer()
{
    register int c = gc();
    int wejsciowa = 0;
    int i = 0;
    for (; ((c<48 || c>57) && i<2); c = gc(), i++);
    if (i>1)
        return EOF;
    for (; c>47 && c<58 && c != EOF; c = gc()) {
        wejsciowa = (wejsciowa << 1) + (wejsciowa << 3) + c - 48;
    }
    return wejsciowa;
}

Сервис для проверки кода: http://rextester.com/runcode

Буду при очень благодарен за любую помощь)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.11.2015, 01:35
Ответы с готовыми решениями:

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

Дан массив, определить является ли последовательность возрастающей, убывающей, не возрастающей, не убывающей?
Дан массив, определить является ли последовательность возрастающей, убывающей, не возрастающей, не убывающей? Проблема такая, не могу...

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

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.11.2015, 01:35
Помогаю со студенческими работами здесь

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

Составьте программу на хождения самой длинной возрастающей подпоследовательности данной последовательности
Задана последовательность из N чисел. Составьте программу на хождения самой длинной возрастающей подпоследовательности данной...

Нахождение самой длинной последовательности чисел в тексте
Добрый день :) Передо мной стоит такая задача: найти самую длинную последовательность чисел в файле. Дополнительно надо написать запись в...

В исходной строке b$ определить сумму цифр самой длинной последовательности подряд идущих цифр
В исходной строке b$ определить сумму цифр самой длинной последовательности подряд идущих цифр.

Как в исходной строке b$ определить сумму цифр самой длинной последовательности подряд идущих цифр.
В исходной строке b$ определить сумму цифр самой длинной последовательности подряд идущих цифр.


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача №1: при указании работ (справочник РаботыПоРемонтуСпецтехники),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru