Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 28.03.2018
Сообщений: 11

В одномерном массиве найти произведение элементов, расположенных после первого нулевого элемента

14.04.2018, 12:22. Показов 2636. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Произведение элементов массива, расположенных после первого нулевого элемента, помогите)))

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
74
75
#include "stdafx.h"
#include <stdlib.h>
#include <locale.h>
#include <conio.h>
#include <stdio.h>
#include <ctime>
 
int main()
{
    setlocale(LC_ALL,"rus");
    int n;
    printf("Введите количество элементов:");
    scanf("%d",&n);
    int *x=new int [n];
    srand((unsigned int)time(NULL));
    for(int i=0; i<n; i++)
    {
        x[i]=rand()%100;
        printf("x[%d]=%d\n",i,x[i]);
    }
    //Первый пункт
    int kol=0, in;
    printf("\n Введите номер элемента:\n");
    scanf("%d",&in);
    for (int i=0; i<n; i++)
        if((x[i]<=x[in])&&(in!=i))//&& чтобы сам себя не считал
            kol++;
            printf("Количество элементов не больших элемента x[%d]=%d,равняется: %d",in,x[in],kol);
    //Второй пункт
    int imin,sum=0,min;
    min=x[0];
    for (int i=1; i<n;i++)
        if (x[i]<=min)
        {
            imin=i;
            min=x[i];
        }
            if(imin!=(n-1))//Если номер минимального не равен последнему,ибо нет элементов после минимального и сумма равна нулю
 
            {
                for (int i=imin+1;i<n;i++)
                    sum+=x[i];
        }
        printf("\n\n Сумма элементов расположенных после минимального элемента массива:%d\n\n",sum);
        //Третий пункт
        x[1]=0;
        int inul=-1,prois=0;
        for(int i=0;i<n;i++)
        {
            if(x[i]==0){
                inul=i;
                break;
            }
        }
        if(inul==-1)//если не нашлось ни одного нулевого элемента
        {
            printf("В массиве нет нулевых элементов");
}
else
{
    if(inul!=(n-1))//если Последний элемент равен нулю то произведение не ищем 
    {
        for (int i=inul;i<n;i++)
            prois=prois*x[i];
    printf("Произведение элементов равно: %d",prois);
    }
            else
    {
        printf("Нулевой элемент последний в массиве, поэтому произведение равно: 0");
        }
    }
    delete[]x;
    getch();
    return 0;
    }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.04.2018, 12:22
Ответы с готовыми решениями:

Найти количество элементов массива, расположенных после первого нулевого элемента
Задан массив целых чисел Х(n). Найти количество элементов массива, расположенных после первого нулевого элемента.

В каждой строке матрицы найти сумму элементов расположенных после первого нулевого элемента
Ввести матрицу A n*m, вывести её. В каждой строке найти сумму элементов расположенных после первого нулевого элемента. Значения найденных...

В каждой строке матрицы найти сумму элементов расположенных после первого нулевого элемента
Ввести матрицу A n*m, вывести её. В каждой строке найти сумму элементов расположенных после первого нулевого элемента. Значения найденных...

5
 Аватар для anapshy
531 / 272 / 220
Регистрация: 14.11.2016
Сообщений: 1,052
14.04.2018, 12:50
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
#include <iostream>
#include <array> // array
#include <algorithm> // generate copy fin 
#include <iterator> // ostream_iterator
#include <numeric> // accumulate
#include <cstdlib> // srand rand
#include <ctime> // time
 
const unsigned SIZE{ 10 };
const int MAX_VALUE{ 10 };
 
int main()
{
    std::srand(unsigned(std::time(0)));
    std::array<int, SIZE> arr{};
    // Генерируем массив
    std::generate(arr.begin(), arr.end(), [](void){ return (std::rand() % (MAX_VALUE + 1)); });
    // Выводим массив через пробел
    std::copy(arr.cbegin(), arr.cend(), std::ostream_iterator<int>(std::cout, " "));
    // Ищем элемент равный нулю
    std::array<int, SIZE>::const_iterator it = std::find(arr.cbegin(), arr.cend(), 0);
    // Находим произведение элементов следующих после найденого элемента
    std::cout << std::endl << "Resutl: "
        << std::accumulate(it + 1, arr.cend(), 1,
        [](const int &x, const int &y)
            { return (x * y); }) << std::endl;
}
0
0 / 0 / 0
Регистрация: 28.03.2018
Сообщений: 11
14.04.2018, 12:59  [ТС]
А можно попроще?))
0
 Аватар для anapshy
531 / 272 / 220
Регистрация: 14.11.2016
Сообщений: 1,052
14.04.2018, 13:13
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
#include <iostream>
#include <cstdlib> // srand rand
#include <ctime> // time
 
const unsigned SIZE{ 10 };
const int MAX_VALUE{ 10 };
 
void generate(int *first, int *last)
{
    while (first != last)
        *(first++) = std::rand() % (MAX_VALUE + 1);
}
 
void Print(int *first, int *last)
{
    while (first != last)
        std::cout << *(first++) << ' ';
}
 
int* find(int *first, int *last, const int &value)
{
    while (first != last)
    {
        if (*first == value)
            return first;
        ++first;
    }
    return last;
}
 
int accumulate(int *first, int *last)
{
    int res{1};
    while (first != last)
        res *= *(first++);
    return res;
}
 
int main()
{
    std::srand(unsigned(std::time(0)));
    int arr[SIZE]{};
    int * const begin{arr};
    int * const end{arr + SIZE};
    generate(begin, end);
    Print(begin, end);
    int *it = find(begin, end, 0) + 1;
    std::cout << std::endl << "Result: ";
    if (it < end)
        std::cout << accumulate(it, end) << std::endl;
    else
        std::cout << 0 << std::endl;
}
0
 Аватар для Вадим Тукаев
310 / 291 / 116
Регистрация: 23.01.2018
Сообщений: 933
14.04.2018, 13:28
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <algorithm>
#include <iostream>
#include <iterator>
#include <functional>
#include <random>
 
using namespace std;
 
int main()
{
    default_random_engine rng{random_device()()};
    int n;
    cin >> n;
    vector<int> v(n);
    generate(begin(v), end(v), bind(uniform_int_distribution<>(0, 9), ref(rng)));
    copy(cbegin(v), cend(v), ostream_iterator<int>(cout, " "));
    cout << endl;
    auto zero = find(begin(v), end(v), 0);
    if (zero != end(v)) cout << accumulate(next(zero), end(v), 1, multiplies<int>()) << endl;
    return 0;
}
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
14.04.2018, 17:17
kizen, сбросьте оригинал условия задачи
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.04.2018, 17:17
Помогаю со студенческими работами здесь

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

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

Вычислить сумму элементов, произведение элементов с положительными значениями, стоящих после первого нулевого элемента
Дан одномерный массив длинной N.Вычилить сумму всех элементов произведение всех элементов с положительнымт значениями, стоящих после...

Вычислить произведение всех элементов с положительными значениями, стоящих после первого нулевого элемента
Дан одномерный массив длиной N.Вычислить произведение всех элементов с положительными значениями ,стоящих после первого нулевого элемента.

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


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru