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

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

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

Произведение чисел в массиве между двумя первыми отрицательными элементами - C++

07.04.2013, 21:57. Просмотров 721. Ответов 4
Метки нет (Все метки)

Одномерный массив, задается рандомно, надо найти произведение чисел между первым и вторым отрицательным числом. Вот то, что у меня получилось...
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
#include<iostream>
#include<time.h>
#include<stdlib.h>
using namespace std;
int main()
{
    int i,n,d,k,p,s=0;
    cout<<"n=";
    cin>>n;
    srand(time(NULL));
    int mas[n];
    int arr[2];
    for(i=0;i<n;i++)
    {
    mas[i]=rand()%50-20;
    cout<<mas[i]<<" ";
    }
    while (s<=2)
    {
    for(i=0;i<n;i++)
    {
        if(mas[i]<0)
        {
            arr[0]=i;
            s++;
            break;
        }
        i++;
        if(mas[i]<0)
        {
            arr[1]=i;
            s++;
            break;
        }
    }
    }
    cout<<"arr1="<<arr[0]<<endl;
    cout<<arr[1]<<endl;
    p=1;
    for(i=arr[1];i<arr[2];i++)
    {
    p=p*mas[i];
    }
    cout<<"p="<<p;
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.04.2013, 21:57
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Произведение чисел в массиве между двумя первыми отрицательными элементами (C++):

Произведение элементов массива расположенных между двумя первыми нулевыми элементами массива - C++
Помогите доработать пожалуйста, последний этап не могу сообразить. #include #include #include #include using std::cout;...

Найти максимальную сумму чисел, расположенных между двумя отрицательными элементами массива - C++
#include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;locale.h&gt; #include &lt;time.h&gt; using namespace std; int main() { ...

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

Найти произведение элементов массива расположенных между первым и последним отрицательными элементами - C++
Задан массив X(n) найти : -сумму нечетных элементов массива; -произведение элементов массива расположенных между первым и последним...

Вычислить произведение элементов массива расположенных между первым и последним отрицательными элементами - C++
произведение эле-ментов массива, расположенных между первым и последним отрицатель-ными элементами.

Найти в массиве произведение элементов между первым и вторым нулевыми элементами, и количество простых чисел - C++
В массиве, состоящем из n натуральных элементов, вычислить: - произведение элементов массива, расположенных между первым и вторым...

4
yoghurt92
374 / 345 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
07.04.2013, 22:33 #2
poctek, получилось, а что не правильно?

Добавлено через 18 минут
poctek, вопрос первый, вы компилировали программу? у вас статический массив, его размер - константа, программа не скомпилируется, второе - что не получается?
0
poctek
0 / 0 / 0
Регистрация: 19.01.2013
Сообщений: 4
07.04.2013, 23:07  [ТС] #3
не могу найти отрицательные числа, а значит и произведение. Массив статистический потому что в него кладу только два значения: первое отрицательное и второе
0
yoghurt92
374 / 345 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
07.04.2013, 23:10 #4
poctek, вот вам мой вариант

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
#include <iostream>
#include <array>
#include <time.h>
#include <stdlib.h>
#include <algorithm>
#include <numeric>
#include <functional>
using namespace std;
 
void random(int &elem){
    elem = -10 + rand() % 20;
}
 
bool predikat(int elem){
    return elem < 0;
}
 
int main()
{
    srand(time(NULL));
 
    const int size = 10;
    array<int, size> coll;
 
    for_each(coll.begin(), coll.end(), random);
 
    cout << "Array: ";
    copy(coll.begin(), coll.end(), std::ostream_iterator<int>(cout, " "));
 
    int product;
    array<int, size>::iterator pos1, pos2;
 
    pos1 = find_if(coll.begin(), coll.end(), predikat);
    pos2 = find_if(pos1 + 1, coll.end(), predikat);
 
    if(pos1 != coll.end() && pos2 != coll.end()){
        product = accumulate(pos1, pos2, 1, multiplies<int>());
        cout << "\nProduct: " << product << "\n\n";
    }
    else if(pos1 == coll.end() || pos2 == coll.end())
        cout << "\nAdd second negative element!\n\n";
    else
        cout << "\nNo negative elements!\n\n";
 
    return 0;
}
1
poctek
0 / 0 / 0
Регистрация: 19.01.2013
Сообщений: 4
07.04.2013, 23:35  [ТС] #5
Спасибо большое!
0
07.04.2013, 23:35
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.04.2013, 23:35
Привет! Вот еще темы с ответами:

Вывести сумму чисел из данного набора, расположенных между первыми двумя нулями - C++
№1 Дано целое число N и набор из N целых чисел, содержащий по крайней мере два нуля. Вывести сумму чисел из данного набора, расположенных...

Найти сумму элементов массива, находящихся в массиве между первым и последним отрицательными элементами - C++
Уважаемые програмисты помогите решить задачи.:( 1. Написать программу, определяющая сумму элементов массива, находящихся в массиве...

вычислите сумму элементов, которая расположена между теми элементами,которые сами расположены между первым и последним отрицательными элементами. - C++
вычислите сумму элементов, которая расположена между теми элементами,которые сами расположены между первым и последним отрицательными...

Найти произведение элементов расположенных между двумя нулевыми элементами - C++
а вот эту можете решить?)) Массив А (100) содержит два нулевых элемента (номера которых не известны). Найти произведение элементов...


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

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

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