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

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

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

Найти максимальный элемент массива и произведение элементов до него - C++

19.02.2014, 10:47. Просмотров 273. Ответов 3
Метки нет (Все метки)

помогите, пожалуйста!

Дан массив А из 10 целых чисел введенных с клавиатуры, найти максимальный элемент и произведение элементов до него.

max находит правильно, а вот с произведением элементов до него беда. Если перед max нет элементов, нужно это вывести. Если до max единицы, нужно вывести, чтобы показать, что нач.знач. p=1 умножалось на элементы.

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
#include"stdafx.h"
#include"iostream"
using namespace std;
void main ()
{ int i, a[10], max, maxN, p=1;
 
for (i=0; i<10; i++)
    cin >> a[i];
max=a[0];
maxN=0;
for (i=1; i<10; i++)
    if (a[i]>=max)
        {max=a[i];
        maxN=i;}
cout<<"max="<< max;
 
for(i=0;i>maxN; i++);
if(i<=maxN)
    {p=p*a[i];
cout<<"p="<< p;}
    else
    cout << "no" << endl;
system("pause");
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.02.2014, 10:47
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти максимальный элемент массива и произведение элементов до него (C++):

Дан массив А из 10 целых чисел введенных с клавиатуры, найти максимальный элемент и произведение элементов до него - C++
помогите, пожалуйста! Дан массив А из 10 целых чисел введенных с клавиатуры, найти максимальный элемент и произведение элементов до...

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

Найти максимальный элемент массива и все числа до него заменить нулями - C++
#include &lt;iostream&gt; using namespace std; void Zamena(int a, int n,int&amp; max, int&amp; maxI) { for (int i = 0; i &lt; n; i++) if...

Найти максимальный элемент массива, и удалить после него все нечетные элементы - C++
В массиве A(n) определить максимальный элемент .удалить после максимального все нечетные элементы

Вычислить произведение элементов, больших заданного числа М, а также максимальный элемент массива - C++
Одномерный массив. Создать числовой массив A. Вычислить произведение элементов больших заданного числа М, а также максимальный элемент...

Найти максимальный элемент массива и сумму элементов массива по условию - C++
Доброе утро!...Уже и не знаю в чём дело....Вот тебе и заочное отделение:) Написать программу, работающую с одномерным вещественным...

3
Ilot
Модератор
Эксперт С++
1823 / 1181 / 232
Регистрация: 16.05.2013
Сообщений: 3,118
Записей в блоге: 5
Завершенные тесты: 1
19.02.2014, 11:57 #2
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
C++
1
for(i=0;i>maxN; i++);
Даже боюсь спрашивать для чего необходима такая жесткая конструкция...
C++
1
2
3
4
5
6
if (maxN == 0) cout << "Максимальный элемент первый в массиве!" <<endl;
else {
for(i=0;i < maxN; i++)
    p *= a[i];
    cout << "Произведение элементов до максимального: " << p << endl;
}
1
Тамика
Котовчанин
917 / 461 / 145
Регистрация: 16.02.2010
Сообщений: 3,229
Записей в блоге: 27
19.02.2014, 12:12 #3
Цитата Сообщение от MaKN Посмотреть сообщение
for(i=0;i>maxN; i++);
if(i<=maxN)
* * {p=p*a[i];
А почему тогда считаете сумму элементов [delete] без верхнего предела...
0
bradobrei
Продам уран 238U
119 / 119 / 23
Регистрация: 22.01.2013
Сообщений: 298
19.02.2014, 13:19 #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
#include <iostream>
#include <cstdlib>
using namespace std;
#define n 10
int main(){
    int mas[n];
    int max = -9999, multi = 1, pos = -1;
    int count1 = 0;
    cout<<"Elements: ";
    for(int i = 0; i < n; i++){ 
        mas[i] = rand()% 20 + 1;
        cout<<mas[i]<<" ";
        if(max < mas[i]){
            max = mas[i];
            pos = i;
        }
    }
    cout<<endl<<"Max = "<<max;
    if(pos == 0)
        cout<<endl<<"перед max нет элементов";
    else {
        for(int i = 0; i < pos; i++){
            if(mas[i] == 1)
                count1 ++;
            multi *= mas[i];
        }
    if(count1 == (pos - 1))
        cout<<endl<<"Элементы до max равны 1";
    else
        cout<<endl<<"multi = "<<multi;
    }
return 0;
}
0
19.02.2014, 13:19
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.02.2014, 13:19
Привет! Вот еще темы с ответами:

Дана матрица вещественных чисел. Найти максимальный элемент и наиболее удалённый от него (по значению) элемент матрицы. - C++
Дана матрица вещественных чисел. Найти максимальный элемент и наиболее удалённый от него (по значению) элемент матрицы. Поиск осуществлять...

Найти максимальный элемент среди отрицательных элементов массива - C++
Привет. Помогите написать код. Необходимо используя классы найти максимальный элемент среди отрицательных элементов массива.

Найти максимальный элемент массива среди четных элементов - C++
Дан массив а(10), заполненный датчиком случайных чисел. Найти максимальный элемент массива среди четных элементов.

Найти сумму тех элементов массива, цифровая запись которых дает четную сумму цифр, а также найти максимальный элемент массива - C++
Вот, что есть.Помогите довести до ума! #include &lt;cstdlib&gt; #include &lt;iostream&gt; #include &lt;math.h&gt; using namespace std; void...


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

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

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