0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71

Вычисление произведения элементов массива, расположенных после максимального по модулю элемента

15.01.2019, 08:03. Показов 2124. Ответов 16
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите с кодом.
Не работают:
1) вычисление произведения элементов массива, расположенных после максимального по модулю элемента
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
52
53
54
55
56
57
58
59
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <cmath>
using namespace std;
int main(){
    setlocale(LC_ALL,"russian");
    double *array;
    int n = 10;
    srand(time(NULL));
    array=new double[n];
    
    for(int i = 0; i < n; i++)
    {
        array[i] = (double)(rand()%100)+(double)(rand()%10)+(double)(rand()%1);   
    }
    for(int i = 0; i < n; i++)
    {
        cout << array[i]<<" ";
    }
    cout<<endl;
 
//1-----------------------------------------------      
    int c, counter = 0;
    cout << "Vvedite C: ";
    cin >> c;
    for(int i = 0; i < n; i++)
        if(array[i] > c)
            counter++;
    cout << "Proizvedenie massiva bolshe C: " << counter;
//2-----------------------------------------------  
    int max = abs(array[0]);
    counter = 0;
    for(int i = 0; i < n; i++)
        if(abs(array[i]) > max){
            counter = i;
            max = abs(array[i]);
            counter = i;
        }
 
    int mult = 1;
    for(int i = counter+1; i < n; i++)
        mult *= array[i];
    cout << "\nProizvedenie elementov massiva raspolozhenyh posle max po modulu elementa: " << mult;
//3-----------------------------------------------      
    for(int i = 0; i < n; i++)
        if(array[i] != 0 && abs(array[i] - 1) > abs(array[i])){
            int tmp = array[i];
            for(int j = 0; j < i; j++)
                array[i - j] = array[i - j - 1];
            array[0] = tmp;
        }
 
    cout << "\philtr massiva:\n";
    for(int i = 0; i < n; i++)
        cout << array[i] << ' ';
    cout << endl;
 
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.01.2019, 08:03
Ответы с готовыми решениями:

Произведение элементов массива расположенных после максимального по модулю элемента (С)
Помогите пожалуйста написать программу. Очень буду Вам благодарен, очень срочно надо. В одномерном массиве состоящем из n вещественных...

Произведение элементов массива, расположенных после максимального по модулю элемента
Помогите написать программу. Я работаю с программой MS Visual Studio 2005. В одномерном массиве, состоящем из п целых элементов,...

Найдите произведение элементов массива, расположенных после максимального по модулю элемента
Найдите произведение элементов массива, расположенных после максимального по модулю элемента.

16
447 / 333 / 172
Регистрация: 01.07.2015
Сообщений: 1,161
15.01.2019, 17:39
Цитата Сообщение от Spectr456 Посмотреть сообщение
фильтр массива(слева направо по возрастанию)
C++
1
sort(a, a + n);
Или сортировка пузырьком, которая гуглится на раз

Цитата Сообщение от Spectr456 Посмотреть сообщение
вычисление произведения элементов массива, расположенных после максимального по модулю элемента
C++
1
for_each(max_element(a, a + n, [](const auto& a, const auto& b) { return abs(a) < abs(b); }) + 1, n, [&prod](const auto& a) { prod *= a; });
0
0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71
15.01.2019, 21:08  [ТС]
а можно пожалуйста поподробнее куда именно мне это записать
0
447 / 333 / 172
Регистрация: 01.07.2015
Сообщений: 1,161
15.01.2019, 21:46
Цитата Сообщение от ReDoX Посмотреть сообщение
вычисление произведения элементов массива, расположенных после максимального по модулю элемента
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <algorithm>
#include <iostream>
 
using namespace std;
 
int main() {
  int n;
  cin >> n;
 
  double* a = new double[n];
  for (int i = 0; i < n; ++i)
    cin >> a[i];
 
  double prod = 1.0;
 
  int pos = distance(a, max_element(a, a + n, [](const auto& a, const auto& b) { return fabs(a) < fabs(b); }));
 
  for (++pos; pos < n; ++pos)
    prod *= a[pos];
 
  cout << prod;
}
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
15.01.2019, 23:42
Цитата Сообщение от Spectr456 Посмотреть сообщение
расположенных после максимального по модулю элемента
расположенных после первого максимального по модулю элемента
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
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <cmath>
using namespace std;
 
int main()
{
    srand((int)time(0));
    int n, imax_mod=0;
    cout <<"n="; cin >>n;
 
    double*a = new double[n], max_mod=0.0, mult=1.0, eps=1e-9;
 
    for (int i = 0; i < n; i++)
      {
      a[i]=rand()%19 - 9;
      if(i==0 || fabs(a[i])>max_mod) {max_mod=fabs(a[i]);imax_mod=i;}
      cout <<a[i]<<" ";
      }
     
    cout <<"\nmaximum by module elements = "<<a[imax_mod];
    cout <<"\nposition first maximum by module = "<<imax_mod+1<<"\n";
    
    if(imax_mod!=n-1)
    {
    for (int i = imax_mod+1; i < n; i++)        
        mult*=a[i];
        if (mult>-eps&&mult<eps) mult=0.0;
        cout <<"mult="<<mult<<"\n";
    }
    else cout <<"Element after maximum by module are absent\n";
    
    delete[]a;
system("pause");
return 0;
}
0
0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71
22.01.2019, 21:55  [ТС]
Часть проблемы решена, но осталась проблема с произведением элементов массива(показывает какие то чудесные, отличные от реальности числа)
Код:
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <cmath>
using namespace std;
int main(){
    setlocale(LC_ALL,"russian");
    double *array;
    int n = 10;
    srand(time(NULL));
    array=new double[n];
    
    for(int i = 0; i < n; i++)
    {
        array[i] = (double)(rand()%100)+(double)(rand()%10)+(double)(rand()%1);   
    }
    for(int i = 0; i < n; i++)
    {
        cout << array[i]<<" ";
    }
    cout<<endl;
 
//1     
    int c, counter = 0;
    cout << "Vvedite C: ";
    cin >> c;
    for(int i = 0; i < n; i++)
        if(array[i] > c)
            counter++;
    cout << "Proizvedenie massiva bolshe C: " << counter;
//2  
    int max = abs(array[0]);
    counter = 0;
    for(int i = 0; i < n; i++)
        if(abs(array[i]) > max){
            counter = i;
            max = abs(array[i]);
            counter = i;
        }
 
    int mult = 1;
    for(int i = counter+1; i < n; i++)
        mult *= array[i];
    cout << "\nProizvedenie elementov massiva raspolozhenyh posle max po modulu elementa: " << mult;
//3
    for(int i = 0; i < n; i++)
        if(array[i] != 0 && abs(array[i] - 1) < abs(array[i])){
            int tmp = array[i];
            for(int j = 0; j < i; j++)
                array[i - j] = array[i - j - 1];
            array[0] = tmp;
        }
 
 
    for(int i = 1; i < n; i++)
    {
        for(int m = 0; m < n-i; m++)
        {
            if(array[m] > array[m+1])
            {
                int temp = array[m];
                array[m] = array[m+1];
                array[m+1] = temp;
            }
        }
    }
    cout << "\nSorted array: "<< endl;
    for(int i = 0; i < n; i++)
    {
        cout << array[i] << " ";
    }
    cout << endl;
}
Прошу помогите с ним
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
22.01.2019, 23:32
Цитата Сообщение от Spectr456 Посмотреть сообщение
проблема с произведением элементов массива
сбросил же Вам работающий код. что в нём не устраивает ?
0
0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71
23.01.2019, 16:53  [ТС]
У меня просто такое задание :
В одномерном массиве, состоящем из n вещественных элементов, вычислить:

1) количество элементов массива, больших С;

2) произведение элементов массива, расположенных после максимального по модулю элемента;

3) преобразовать массив таким образом, чтобы сначала располагались все отрицательные элементы, а потом — все положительные (элементы, равные 0, считать положительными).
И мне было бы удобнее в этом же коде добавить вычисление произведения массива, но не знаю как



Заранее за понимание))
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
23.01.2019, 18:19
Spectr456, так просто добавьте в предложенный код переменную int count=0; ввод C (тип - double), а после строки 17 строку:
C++
1
if (a[i]>C) count++;
блок для сдвига отрицательных:
C++
1
2
3
4
5
6
7
8
int k=0;
for (int i = 0; i < n; i++)
        if (a[i]<0.0)
        {
            for (int j = i; j > k; j--)
            swap(a[j],a[j-1]);
            k++;
        }
и напишите что получилось
0
0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71
23.01.2019, 20:46  [ТС]
у меня там ввод рандомных чисел
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
23.01.2019, 22:34
Цитата Сообщение от Spectr456 Посмотреть сообщение
у меня там ввод рандомных чисел
там тоже
0
0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71
26.01.2019, 11:04  [ТС]
немного не понял что куда что добавлять
можете дописать это к коду
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
26.01.2019, 17:19
Лучший ответ Сообщение было отмечено Spectr456 как решение

Решение

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
52
53
54
55
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <cmath>
using namespace std;
 
int main()
{
    srand((int)time(0));
    int n, k, count=0, imax_mod=0;
    cout <<"n="; cin >>n;
 
    double*a = new double[n], C, max_mod=0.0, mult=1.0, eps=1e-9;
 
    for (int i = 0; i < n; i++)
      {
      a[i]=rand()%19 - 9;        
      if(i==0 || fabs(a[i])>max_mod) {max_mod=fabs(a[i]);imax_mod=i;}
      cout <<a[i]<<" ";
      }
    
    cout <<"\nC="; cin >>C;
    for (int i = 0; i < n; i++)
       if (a[i]>C) count++;
        
    cout <<"\ncount="<<count; 
    cout <<"\nmaximum by module elements = "<<a[imax_mod];
    cout <<"\nposition first maximum by module = "<<imax_mod+1<<"\n";
    
    if(imax_mod!=n-1)
    {
    for (int i = imax_mod+1; i < n; i++)        
        mult*=a[i];
        if (mult>-eps&&mult<eps) mult=0.0;
        cout <<"mult="<<mult<<"\n";
    }
    else cout <<"Element after maximum by module are absent\n";
    
    k=0;
    for (int i = 0; i < n; i++)
        if (a[i]<0.0)
        {
            for (int j = i; j > k; j--)
            swap(a[j],a[j-1]);
            k++;
        }
    
    for (int i = 0; i < n; i++)      
      cout <<a[i]<<" ";
      cout <<"\n";    
    
    delete[]a;
system("pause");
return 0;
}
строки 27-28 информационные (по условию не требуются)
1
0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71
27.01.2019, 17:44  [ТС]
Правильно ли работает произведение элементов массива, расположенных после максимального по модулю элемента ?
Миниатюры
Вычисление произведения элементов массива, расположенных после максимального по модулю элемента  
0
0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71
27.01.2019, 19:06  [ТС]
Да и фильтр как то странно работает
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
27.01.2019, 19:48
Spectr456, это Вы про какой код ? тот, который предложил я при таких данных выдаёт правильно:
n=5
8 7 7 1 -2
C=2

count=3
maximum by module elements = 8
position first maximum by module = 1
mult=-98
-2 8 7 7 1

mult=7*7*1*(-2)=-98 и при других данных тоже правильно

Цитата Сообщение от Spectr456 Посмотреть сообщение
Да и фильтр как то странно работает
что ещё за фильтр ?
0
0 / 0 / 0
Регистрация: 01.03.2018
Сообщений: 71
27.01.2019, 21:05  [ТС]
А, всё понял, спасибо)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.01.2019, 21:05
Помогаю со студенческими работами здесь

произведение элеменов массива, расположенных после максимального по модулю элемента
здравствуйте!помогите пожалуйста решить задачу: в одномерном массиве состоящем из n веществ.элементов вычислить: 1)кол-во элементов...

Произведения элементов массива расположенных после максимального по модулю элемента
В одномерном массиве состоящем из n элементов вычислить: 1. Количество элементов массива, больших С 2. Произведения элементов массива...

Произведение элементов массива, расположенных после максимального по модулю элемента
В одномерном массиве, состоящем из n вещественных элементов, вычислить :Произведение элементов массива, расположенных после максимального...

Произведение элементов массива, расположенных после максимального по модулю элемента
Привет всем :) Делаю тут задачку и не могу найти ошибку, первое условие выполняется, а вот второе - нет...Постоянно пишет 0 :( Вот само...

Произведение элементов массива, расположенных после максимального по модулю элемента
В одномерном массиве, состоящем из n вещественных элементов, вычислить: А) сумму положительных элементов массива (это я сделала) Б) !!...


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

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

Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru