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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Garret192
1 / 1 / 0
Регистрация: 21.10.2009
Сообщений: 84
#1

Массив - C++

20.01.2010, 20:47. Просмотров 331. Ответов 5
Метки нет (Все метки)

Привет.Помогите пожалуйста решить задачу.
Определить в одномерном массиве максимальную длину последовательности расположенных подряд возрастающих значений и индекс ее начала.
Вот мой код, но он неправилен.
У меня получается просто найти длинну последовательности.
А как когда в массиве две и более последовательностей, найти длинну одной,второй и т.д и сравнив их найти максимальную.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include<iostream.h>
#include<stdlib.h>
const int n=101;
int main()
{
 int a[n],n,i,sum,j;
 sum=1;
 cout<<"Vvedi n ";
 cin>>n;
 cout<<"Vvedi massiv ";
 for(i=0;i<n;i++)
  cin>>a[i];
 for(i=0;i<n;i++)
  cout<<a[i]<<" ";
 for(i=0;i<n-1;i++)
  if(a[i]<a[i+1])
     sum+=1;
 cout<<"Max dlinna="<<sum;
 system ("pause");
 return 0;
}
Заранее спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.01.2010, 20:47     Массив
Посмотрите здесь:

Дан массив A(23). Переписать в новый массив все элементы, расположенные после последнего отрицательного. C++
C++ Массив: Получить новый массив В по следующему правилу: В1=А1+А10
C++ Найти ошибку. Записать 20 целых чисел в массив. Переписать отрицательные в массив А, а положительные в Б
Файлы и массив (сделать так, чтобы массив заполнялся значениями из этого же файла) C++
Массив: Получить массив, который содержит все элементы исходного массива, кратные трем C++
C++ Включить новый элемент в массив, упорядоченный по возрастанию, с сохранением упорядоченности. (рандомный массив)
C++ Задано массив строк произвольной длины. Отформатировать данный массив по ширине поля.
Записать все положительные элементы матрицы в массив arrP, а отрицательные - в массив arrN C++
Задан массив и матрица, получить другой массив по правилу C++
C++ Переписать все элементы из этих массивов в массив С так, чтобы массив С был упорядоченным
C++ Создать линейный массив, отсортировать его в другой массив, вывести адрес всех елементов
C++ Создать линейный массив, отсортировать его в другой массив, вывести адрес всех елементов

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
accept
4819 / 3239 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
21.01.2010, 09:19     Массив #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
#include <stdio.h>
#include <stdlib.h>
 
int main(void) /* C89 ANSI */
{
    int n[] = { 1, 2, 7, 1, 2, 3, 3, 2, 1, 1, 2, 3, 4, 4, 3, 2, 1 };
    int size;
    
    int max, curind, maxind;
    int i, flag, sum;
    
    size = sizeof n / sizeof n[0];
    
    max = 0;
    flag = 0;
        
    for (i = 1; i < size-1; i++) {
        
        if (n[i-1] <= n[i]) {
            if (flag == 0) {
                flag = 1;
                sum = 1;
                curind = i-1;
            }
            sum++;
        }
        
        if (n[i-1] > n[i]) {
            if (flag == 1) {
                if (sum > max) {
                    max = sum;
                    maxind = curind;
                }
                flag = 0;
                sum = 0;
            }
        }
        
    }
    
    if (max <= 0)
        printf("nothing" "\n");
    else    
        printf(
            "index = %d, max sequence = %d" "\n",
            maxind,
            max
        );
    
    exit(EXIT_SUCCESS);
}
valeriikozlov
Эксперт C++
4667 / 2493 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
21.01.2010, 11:16     Массив #3
accept, чуть подправил:
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
#include <stdio.h>
#include <stdlib.h>
 
int main(void) /* C89 ANSI */
{
    int n[] = { 1, 2, 7, 1, 2, 3, 3, 2, 1, 1, 2, 3, 4, 5, 6, 7, 8 };
    int size;
    
    int max, curind, maxind;
    int i, flag, sum;
    
    size = sizeof n / sizeof n[0];
    
    max = 0;
    flag = 0;
        
    for (i = 1; i < size; i++) {
        
        if (n[i-1] < n[i] ) {
            if (flag == 0) {
                flag = 1;
                sum = 1;
                curind = i-1;
            }
            sum++;
        }
        
        if (n[i-1] > n[i] || i==size-1) {
            if (flag == 1) {
                if (sum > max) {
                    max = sum;
                    maxind = curind;
                }
                flag = 0;
                sum = 0;
            }
        }        
    }    
    if (max <= 0)
        printf("nothing" "\n");
    else    
        printf(
            "index = %d, max sequence = %d" "\n",
            maxind,
            max
        );    
    exit(EXIT_SUCCESS);
}
accept
4819 / 3239 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
21.01.2010, 14:40     Массив #4
а, не, индекс там с нуля
valeriikozlov
Эксперт C++
4667 / 2493 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
21.01.2010, 14:42     Массив #5
Цитата Сообщение от accept Посмотреть сообщение
это не надо было
В смысле?
accept
4819 / 3239 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
21.01.2010, 14:48     Массив #6
C
1
curind = i-1;
это мне показалось
думал curind = i стало
Yandex
Объявления
21.01.2010, 14:48     Массив
Ответ Создать тему
Опции темы

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