С наступающим Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
aaaallleex
0 / 0 / 0
Регистрация: 20.10.2014
Сообщений: 18
1

Найти в массиве число чередований знака

15.12.2014, 01:09. Просмотров 345. Ответов 2
Метки нет (Все метки)

В массиве Z(m) найти число чередований знака, то есть число переходов с минуса на плюс или с плюса на минус.
Проблема с нулями, когда 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
#include <ctime>
#include <cstdlib>
#include <iostream>
using namespace std;
 
int main()
{
    const size_t n = 10;
    int a[n];
 
    srand(time(NULL));
    for (size_t i = 0; i < n; ++i)
    {
        a[i] = rand() % 20 - 10;
        cout << a[i] << ' ';
    }
    cout << '\n';
 
    size_t c = 0;
    for (size_t i = 1; i < n; ++i)
    if ((a[i - 1] <= 0) && (a[i] > 0) || (a[i - 1] >= 0) && (a[i] < 0)) ++c;
 
    cout << "result: " << c << endl;
    return 0;
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.12.2014, 01:09
Ответы с готовыми решениями:

В целочисленном массиве найти число чередований знака, то есть число переходов с минуса на плюс или с плюса на минус.
В целочисленном массиве найти число чередований знака, то есть число переходов...

Определить число чередований знака элементов в массиве
Задан массив из N вещественных элементов. Определить число чередований знака,...

Найти число перемен знака в заданом одномерном массиве
Задано одномерный массив чисел {ai}(i=1,2,...,n). Найти число перемен знаков в...

В заданном массиве определите число соседств двух чисел разного знака
В заданном массиве определите число соседств двух чисел разного знака.

Определите в двумерном числовом массиве число соседства с двух чисел разного знака
Помогите. Определите в двумерном числовом массиве число соседства с двух чисел...

2
Yan12_04
30 / 30 / 35
Регистрация: 05.11.2014
Сообщений: 117
15.12.2014, 06:27 2
C++
1
if (((a[i - 1] <= 0) && (a[i] > 0)) || ((a[i - 1] >= 0) && (a[i] < 0)))
0
zss
Модератор
Эксперт С++
7506 / 6864 / 4335
Регистрация: 18.12.2011
Сообщений: 18,174
Завершенные тесты: 1
15.12.2014, 08:36 3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
int c=0;
bool plus=false;
if(a[0]>0)
    plus=true;
for(int i=1;i<n;i++)
{
   if(plus && a[i]<0)
   {
          c++;
          plus=false;
   }else
   if(!plus && a[i]>0)
   {
          c++;
          plus=true;
   }else
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.12.2014, 08:36

Алгоритмы (найти последнюю перемену знака в массиве)
Подскажите,как найти последнюю перемену знака в массиве,без использования...

В данном массиве найти самую длинную группу из записанных подряд элементоводного знака
1.В данном массиве найти самую длинную группу из записанных подряд...

Обработать результаты замеров температур: найти минимум, число изменений знака
Задача на линейный массив. Здравствуйте форумчане) Помогите решить задачу....


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

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

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