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

Подсчитать количество участков, которые образуют непрерывные последовательности чисел - C++

Восстановить пароль Регистрация
 
nikolads
0 / 0 / 0
Регистрация: 28.12.2011
Сообщений: 11
29.12.2011, 15:12     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #1
Я составил текст программы, но не могу написать отладку. Помогите пожалуйста написать отладку к программе. (очень нужно написать сегодня, помогите пожалуйста.)
Задача: Объявить массив целых чисел и заполнить его случайными значениями. Размер массива и диапазон значений его элементов заданы в задании. В задании указано также, какую обработку массива следует произвести. Размерность массива -50. Диапазон значений 0-100. Подсчитать количество участков, которые образуют непрерывные последовательности чисел с неуменьшающимися значениями.

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
#include<cstdlib>
#include<iostream>
#include<ctime>
using namespace std;
int main()
{
int mas[50];
srand(time(NULL));; // dlia randoma 
for (int i=0; i<50; i++ ) 
{
mas[i]=rand()%101; //inicializacia i vyvod massiva
cout << mas[i] << " ";
}
cout << endl;
int count = 0; //schetchik posledovatelnostej
bool stat = false; //peremennaj polorzenij
for(int i = 0; i < 49; i++)
{
if(mas[i+1] >= mas[i] && stat == false)
{
stat = true;
count++;
}
if(mas[i+1] < mas[i])
{
stat = false;
}
}
cout << count;
system("pause");
}
 Комментарий модератора 
Используйте теги форматирования кода!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.12.2011, 15:12     Подсчитать количество участков, которые образуют непрерывные последовательности чисел
Посмотрите здесь:

C++ Подсчитать количество участков, которые образуют непрерывные последовательности чисел с неуменьшающимися значениями
В последовательности из N произвольных чисел подсчитать количество нулей C++
C++ Подсчитать число элементов, входящих в непрерывные последовательности отрицательных чисел
C++ Подсчитать количество нечетных чисел в последовательности
.Определить количество чисел последовательности, у которых цифры образуют возрастающую последовательность. C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
bearwoolfs
 Аватар для bearwoolfs
15 / 15 / 2
Регистрация: 10.01.2011
Сообщений: 275
29.12.2011, 15:19     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #2
не по теме : сейчас админ карать будет , за теги.

Ну для начало int main () должно что-то вернуть. К примеру return 0;
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
29.12.2011, 15:22     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #3
что значит "отладку"?
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
29.12.2011, 15:22     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #4
Цитата Сообщение от bearwoolfs Посмотреть сообщение
Ну для начало int main () должно что-то вернуть. К примеру return 0;
Не обязательно. В int main можно не писать return 0.
Цитата Сообщение от nikolads Посмотреть сообщение
Я составил текст программы, но не могу написать отладку.
nikolads, Что вы подразумеваете под отладкой?
nikolads
0 / 0 / 0
Регистрация: 28.12.2011
Сообщений: 11
29.12.2011, 15:23  [ТС]     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #5
блин помогите пожалуйста с отладкой и все) очень нужно)

Добавлено через 42 секунды
отладка - доказать, что программа работает правильно.
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
29.12.2011, 15:24     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #6
"мамАй клЯнус" не канает?))
nikolads
0 / 0 / 0
Регистрация: 28.12.2011
Сообщений: 11
29.12.2011, 15:26  [ТС]     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #7
"мамАй клЯнус" не канает?))
-нет)
ps. помогите пожалуйста
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
29.12.2011, 15:26     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #8
Цитата Сообщение от nikolads Посмотреть сообщение
отладка - доказать, что программа работает правильно.
Подсказываю - берете программу, запускаете, высчитываете вручную, сверяете.
nikolads
0 / 0 / 0
Регистрация: 28.12.2011
Сообщений: 11
29.12.2011, 15:29  [ТС]     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #9
как посчитать вручную) я не очень разбираюсь в непрерывных последовательностях с неуменьшающимися значениями(как он находит их количество). приведите пример из моей программы пожалуйста.
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
29.12.2011, 15:34     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #10
Сообщение было отмечено автором темы, экспертом или модератором как ответ
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
#include<cstdlib>
#include<iostream>
#include<ctime>
using namespace std;
int main()
{
    int mas[50];
    srand(time(NULL));; // dlia randoma
    for (int i=0; i<50; i++ )
    {
        mas[i]=rand()%101; //inicializacia i vyvod massiva
        cout << mas[i] << "\t";
        if ( (i + 1)% 10 == 0 ) cout << endl;
    }
    cout << endl << endl;
 
    int counter = 1; //schetchik posledovatelnostej
 
    for ( int i = 0; i < 49; i ++ )
    {
        cout << "Sequence number " << counter << " :\n";
        while ( true )
        {
            cout << "\t" << mas[i];
            if ( mas[i] > mas[i+1] ) break;
            i++;
        }
        cout << endl;
        counter ++;
    }
    cout << "\nAnswer is: " << counter - 1 << endl;
    system("pause");
}
Добавлено через 27 секунд
показывает все последовательности

Добавлено через 1 минуту
тока я считаю, что одно число тоже последовательность ))
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
29.12.2011, 15:35     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #11
Цитата Сообщение от nikolads Посмотреть сообщение
я не очень разбираюсь в непрерывных последовательностях с неуменьшающимися значениями
Lolwhut??? Вас чему в школе-то учили.
bearwoolfs
 Аватар для bearwoolfs
15 / 15 / 2
Регистрация: 10.01.2011
Сообщений: 275
29.12.2011, 15:39     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #12
Цитата Сообщение от soon Посмотреть сообщение
Не обязательно. В int main можно не писать return 0.

nikolads, Что вы подразумеваете под отладкой?
а почему ./? int должно что-то вернуть ? вроде так ?
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
29.12.2011, 15:41     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #13
Цитата Сообщение от bearwoolfs Посмотреть сообщение
а почему ./? int должно что-то вернуть ? вроде так ?
да по умолчанию он 0 возвращает. стандарт такое допускает
но пропускать не кашерно просто. мало ли.
bearwoolfs
 Аватар для bearwoolfs
15 / 15 / 2
Регистрация: 10.01.2011
Сообщений: 275
29.12.2011, 15:43     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #14
nikolads
У вас же написан цикл заполняющий массив . подставляйте случайные числа и просто сравнивайте , распишите на бумаге.
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
29.12.2011, 15:55     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #15
куда пропал аффтар?
подходит тебе мой вариант или где?
Nicky
3 / 3 / 0
Регистрация: 21.12.2011
Сообщений: 10
29.12.2011, 16:36     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #16
как посчитать вручную) я не очень разбираюсь в непрерывных последовательностях с неуменьшающимися значениями(как он находит их количество). приведите пример из моей программы пожалуйста.
Вот, например, такая последовательность жутко случайных чисел:

Код
9 2 1 8 4 4 3 7 8 6 2 6 8 1 4 7
Чтобы Вам было легче понять, что есть "непрерывная последовательность с неуменьшающимися значениями", или, что то же самое, просто "неубывающая последовательность", я представлю ее с "высотой" каждого числа:

Код
9                              
      8         8       8      
              7               7
                  6   6        
                               
        4 4                 4  
            3                  
  2                 2          
    1                     1
Здесь неубывающие последовательности - следующие:
"1 8" (не "1 8 4", потому что 4 < 8),
"4 4" (4 ведь не меньше 4, поэтому эта последовательность не убывает),
"3 7 8",
"2 6 8", и
"1 4 7".

Для проверки правильности работы программы запустите ее, например, с этой последовательностью и сверьте результаты.
nikolads
0 / 0 / 0
Регистрация: 28.12.2011
Сообщений: 11
29.12.2011, 16:41  [ТС]     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #17
это очень помогло - огромное спасибо. Только хотел спросить - как сделать, чтобы не считало одно число, последовательность чисел - 2 и более чисел.

Добавлено через 3 минуты
co6ak , как сделать чтобы не считало одно число - а так вообще очень помог
co6ak
Кошковед
 Аватар для co6ak
402 / 495 / 29
Регистрация: 12.04.2010
Сообщений: 1,392
29.12.2011, 16:42     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #18
Сообщение было отмечено автором темы, экспертом или модератором как ответ
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
#include<cstdlib>
#include<iostream>
#include<ctime>
using namespace std;
int main()
{
    int mas[50];
    srand(time(NULL));; // dlia randoma
    for (int i=0; i<50; i++ )
    {
        mas[i]=rand()%101; //inicializacia i vyvod massiva
        cout << mas[i] << "\t";
        if ( (i + 1)% 10 == 0 ) cout << endl;
    }
    cout << endl << endl;
 
    int counter = 0; //schetchik posledovatelnostej
 
    for ( int i = 0; i < 49; i ++ )
    {
 
 
        if ( mas[i] <= mas[i+1] )
        {
            cout << "Sequence number " << ++counter << " :\n";
            while ( true )
            {
                cout << "\t" << mas[i];
                if ( mas[i] > mas[i+1] ) break;
                i++;
            }
            cout << endl;
 
        }
    }
    cout << "\nAnswer is: " << counter << endl;
    system("pause");
}
Добавлено через 25 секунд
делать предварительную проверку и только потом запускать этот дикий цикл

Добавлено через 28 секунд
вся печаль кода в том, что он дважды проверяет одни и те же числа. зато наверняка
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.12.2011, 16:51     Подсчитать количество участков, которые образуют непрерывные последовательности чисел
Еще ссылки по теме:

Подсчитать количество участков, образующих непрерывные последовательности чисел со значениями C++
C++ Подсчитать количество участков, которые образуют непрерывные последовальности
C++ Подсчитать количество участков

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

Или воспользуйтесь поиском по форуму:
nikolads
0 / 0 / 0
Регистрация: 28.12.2011
Сообщений: 11
29.12.2011, 16:51  [ТС]     Подсчитать количество участков, которые образуют непрерывные последовательности чисел #19
co6ak, огромное спасибо. и другие тоже спасибо(очень помогло объяснение последовательности с неуменьшающимися значениями). Огромное спасибо.
Yandex
Объявления
29.12.2011, 16:51     Подсчитать количество участков, которые образуют непрерывные последовательности чисел
Ответ Создать тему
Опции темы

Текущее время: 15:41. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru