Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

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

Массив - C++

20.01.2010, 20:47. Просмотров 340. Ответов 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;
}
Заранее спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.01.2010, 20:47
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Массив (C++):

Ввести массив А. В массив В перенести все элементы массива А, стоящие правее максимального элемента, и имеющие нечетный индекс. Массив В отсортировать - C++
Добрый Вечер! Написал первую часть программы по этому заданию&quot;Ввести массив А. В массив В перенести все элементы массива А, стоящие правее...

Массив: Как скопировать двумерный массив в другой массив? - C++
Как скопировать двумерный массив в другой массив?

Дан массив целых чисел,произвести для него следующие операции: для каждого из чисел ,входящего в массив,указать,сколько раз оно входит в массив... - C++
помогите!!!((( дан массив целых чисел,произвести для него следующие операции: для каждого из чисел ,входящего в массив,указать,сколько...

Файл: Загрузка данных из файла: первый столбец записывался в 1й массив, второй столбец - во 2й массив, а 3й столбец - в 3й массив. - C++
Есть текстовый файл, в нем 3 столбца чисел (число строк заранее неизвестно). Напишите пожалуйста код, чтобы первый столбец записывался в...

Сжать массив, выбросив из него отрицательные элементы - массив становится пустым - C++
Задачка такая: Разработать программу, обеспечивающую ввод с клавиатуры целых чисел и сохранение их в одномерном массиве. Ввод...

Дан массив А(4,4). Сформировать массив В(4) из среднеарифметических значений элементов в каждой строке. - C++
Дан массив А(4,4). Сформировать массив В(4) из среднеарифметических значений элементов в каждой строке. Посмотрите пожалуйста... ...

5
accept
4825 / 3246 / 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);
}
0
valeriikozlov
Эксперт С++
4673 / 2499 / 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);
}
2
accept
4825 / 3246 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
21.01.2010, 14:40 #4
а, не, индекс там с нуля
0
valeriikozlov
Эксперт С++
4673 / 2499 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
21.01.2010, 14:42 #5
Цитата Сообщение от accept Посмотреть сообщение
это не надо было
В смысле?
0
accept
4825 / 3246 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
21.01.2010, 14:48 #6
C
1
curind = i-1;
это мне показалось
думал curind = i стало
0
21.01.2010, 14:48
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.01.2010, 14:48
Привет! Вот еще темы с ответами:

Заполнить массив первыми ста простыми числами, и вывести массив на экран - C++
Объявите одномерный целочисленный массив в котором не более 100 элементов выполните генерацию массива первыми 100 простыми числами....

Массив: найти номера столбцов с положительными элементами и записать их в одномерный массив - C++
ввести двумерный массив I . найти номера столбцов с положительными элементами и записать их в одномерный массив, отобразить его на экране. ...

Переписать положительные элементы массива K,кратные пяти в массив M,а остальные-в массив Q. - C++
Дан массив K(N).Переписать положительные элементы массива K,кратные пяти в массив M,а остальные-в массив Q.

Дан массив. Записать во второй массив все элементы, не совпадающие с минимальным - C++
Дан массив M(14).Записать в массив B все элементы , не совпадающие с минимальным. Cоставить блок схему программы


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

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

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