С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 11.10.2019
Сообщений: 7
1

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

13.10.2019, 23:30. Показов 2252. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Возникли некоторые проблемы с написанием программы. Суть её такова: необходимо создать программу, которая находит произведение между первым и вторым нулевым элементами. Предусмотреть ввод как с клавиатуры, так и с помощью заполнения случайными числами. В случае если нулей не окажется или же он будет только один, выводить соответствующую ошибку. Задание вроде бы сделал, но в силу отсутствия знаний не знаю как что исправить. В подобных примерах размер массива указан изначально, а мне нужно вводить с клавиатуры. И из-за этого возникают проблемы. Не могу додумать как это сделать правильно. Поэтому прошу помощи здесь. Вот код:
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#include <iostream>
#include <math.h>
#include <stdio.h>
#include <conio.h>
#include <ctime>
#include <cstdlib>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Rus");
    int i, n, result = 0, b = 1, nul = -1; int fnul, snul = 1;
    cout << "1 - ввод значений массива с клавиатуры. Любая клавиша - использование случайных значений массива." << endl;
    if (_getch() == '1')
    {
        do
        {
            cout << "Введите кол-во элементов массива: ";
            cin >> n;
        }
        while (n < 1 || n > 20);
        int *f = new int[n];
        for (i = 0; i < n; i++)
        {
            cout << "Введите (А" << i + 1 << "): ";
            cin >> f[i];
        }
    }
    else
    {
        do
        {
            cout << "Введите кол-во элементов массива: ";
            cin >> n;
        }
        while (n < 1 || n > 20);
        int* f = new int[n];
        srand(time(NULL));
        for (i = 0; i < n; i++)
        {
            f[i] = rand() % n;
        }
        for (i = 0; i < n; i++)
        {
            cout << "A(" << b << "): " << f[i] << endl;
            b++;
        }
    }
    for (i = 0; i < n; i++) 
    {
        int* f = new int[n];
        if (f[i] == 0) //Использование неинициализированной памяти f.
        {
            fnul = i;
            i = n;
        }
    }
    if (fnul < 0) //Проблемы начинаются отсюда. Run-Time Check Failure #3 - The variable 'fnul' is being used without being initialized.
 
    {
        cout << "Нулей нет, рекомендую перезапустить программу." << endl;
        return -1;
    }
    else
    {
        cout << "Индекс 1-го нулевого элемента: " << fnul << endl;
    }
    for (i = fnul + 1; i < n; i++)
    {
        int* f = new int[n];
        if (f[i] == 0)
        {
            snul = i; 
            i = n; 
        }
    }
    if (snul < snul)
    {
        cout << "2-го нуля нету, результат будет неверным, рекомендую перезапустить программу." << endl;
        return -1;
    }
    else
    {
        cout << "Индекс 2-го нулевого элемента: " << snul << endl;
    }
    for (i = fnul + 1; i < snul; i++)
    {
        int* f = new int[n];
        result *= f[i];
    }
    cout << " перемножение элементов между индексами: " << result << endl << endl;
}
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
13.10.2019, 23:30
Ответы с готовыми решениями:

Найти произведение элементов массива расположенных между первым и вторым отрицательными элементами
Дан массив из N элементов (вещественные числа).Вычислить: 2.произвидение элементов...

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

Найти произведение элементов массива, расположенных между первым и вторым нулевыми элементами
П5.4.Правил Запрещено создавать темы с бессмысленными названиями вроде &quot;Помогите!&quot;, &quot;Вопрос&quot; и...

Произведение элементов массива расположенных между первым и вторым нулевыми элементами
произведение элементов массива расположенных между первым и вторым нулевыми элементами. ...

5
7437 / 5029 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
14.10.2019, 00:35 2
Лучший ответ Сообщение было отмечено explorerbeep как решение

Решение

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>
#include <ctime>
using namespace std;
 
int main()
{
    srand((int)time(0));
    char p;
    int n, ifirst=-1, isecond=-1;
    
    cout << "n="; cin >> n;
 
    double*a = new double[n], mult=1.;
    
    cout << "Make a choice: r or R - random, k or K - keyboard: "; cin >> p;
 
    if (p=='r' || p=='R')
    {
        for (int i = 0; i < n; i++)
            {
            a[i]=rand()%5; 
            cout << a[i] << " ";    
            }
    cout << "\n";
    }
    else if (p=='k' || p=='K')
     {
        cout << "Enter " << n << " elements:\n"; 
        for (int i = 0; i < n; i++)        
            cin >> a[i];       
    }      
    
    for (int i = 0; i < n; i++)        
        if (a[i]==0.) {ifirst=i;break;}
        
    for (int i = 0; i < n; i++)    
        if (a[i]==0. && i!=ifirst) {isecond=i;break;}
        
    if (ifirst==-1) cout << "Null are absent\n";
    else if (isecond==-1) cout << "One null\n";
    else if (isecond==ifirst+1) cout << "Elements between first and second null are absent\n";
    else
    {
    for (int i = ifirst+1; i < isecond; i++)
    mult*=a[i];
    cout << "local mult = " << mult << "\n";
    }      
    
    delete[]a;
system("pause");
return 0;
}
1
Мозгоправ
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
14.10.2019, 00:40 3
Я там поправил:
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
#include <iostream>
#include <ctime>
#include <cstdlib>
#include <conio.h>
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Rus");
    int i, n;
    int* f = NULL;
 
    do
    {
        cout << "Введите кол-во элементов массива: ";
        cin >> n;
    } while (n < 1 || n > 20);
 
    f = new int[n];
 
    cout << "1 - ввод значений массива с клавиатуры. Любая клавиша - использование случайных значений массива." << endl;
    if (_getch() == '1')
    {
        for (i = 0; i < n; i++)
        {
            cout << "Введите (А" << i + 1 << "): ";
            cin >> f[i];
        }
    }
    else
    {
        //srand((unsigned int)time(NULL));  // для отладки закоменчено
        for (i = 0; i < n; i++)
        {
            f[i] = rand() % 5;
            cout << "A(" << i + 1 << "): " << f[i] << endl;
        }
    }
 
    // найти индексы первого и второго нулевого элемента
    int idxs[2];
    int zero_count = 0;
    for (i = 0; i < n; i++)
    {
        if (f[i] == 0)
            idxs[zero_count++] = i;
        if (zero_count == 2)
            break;
    }
 
    if (zero_count < 2) {
        cout << "Не повезло. Должно быть не менее двух нулевых элемента. Найдено нулей " << zero_count << endl;
        delete[] f;
        return EXIT_FAILURE;
    }
 
    long result = f[idxs[0] + 1];
    for (i = idxs[0] + 2; i < idxs[1]; ++i)
    {
        result *= f[i];
    }
    cout << "Произведение элементов между первым и вторым нулевыми элементами: " << result << endl << endl;
 
    delete[] f;
    return EXIT_SUCCESS;
}
Но это, конечно, решение в духе pure-C, но никак не С++
1
7437 / 5029 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
14.10.2019, 01:07 4
L0M, советовать новичку создавать массив на 2 значения ?
0
0 / 0 / 0
Регистрация: 11.10.2019
Сообщений: 7
14.10.2019, 12:08  [ТС] 5
Спасибо за помощь, но пока ждал ответа, смог допереть сам. В любом случае благодарю за потраченное на меня время)
0
Мозгоправ
1745 / 1039 / 468
Регистрация: 01.10.2018
Сообщений: 2,138
Записей в блоге: 2
14.10.2019, 16:19 6
Цитата Сообщение от Yetty Посмотреть сообщение
L0M, советовать новичку создавать массив на 2 значения ?
А чем плох массив на два элемента?

IMHO, конечно, но с массивом получилось аккуратнее. И индексы ищутся за один проход по массиву.

А для новичка... почему нет? Я же не на контейнерах-итераторах-алгоритмах-лямбдах написал.
Массивы ТС знает. Даже умеет создавать в больших количествах динамические массивы. А вот delete[] ещё похоже не проходили.
0
14.10.2019, 16:19
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
14.10.2019, 16:19
Помогаю со студенческими работами здесь

Произведение элементов массива, расположенных между первым и вторым нулевыми элементами
не могу понять, компилятор ругается на вторую функцию. или я что-то неправильно делаю? //В...

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

Дан целочисленный массив размера N. Найти произведение элементов массива, расположенных между первым и вторым нулевыми элементами. зарание благодарен
Помогите пожалуйста написать код Дан целочисленный массив размера N. Найти произведение элементов...

Вычислить произведение элементов массива расположенных между первым и вторым нулевыми элементами
В одномерном массиве, состоящем из п целых элементов, вычислить: 2) произведение элементов...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru