Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
0 / 0 / 0
Регистрация: 18.04.2010
Сообщений: 7
1

Вычислить произведение элементов массива с четными номерами

23.04.2010, 21:02. Просмотров 1975. Ответов 8
Метки нет (Все метки)

помогите задачу решить(
В одномерном массиве, состоящем из N вещественных элементов, вычислить:
произведение элементов массива с четными номерами;
сумму элементов массива, расположенных между первым и последним нулевыми элементами.
Преобразовать массив таким образом, чтобы сначала расолагались все положительные элементы, а потом — все отрицательные (элементы, равные нулю, считать положительными).
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
23.04.2010, 21:02
Ответы с готовыми решениями:

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

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

Вычислить произведение элементов массива с четными номерами
Вычислить произведение элементов массива с четными номерами. Посмотрите пожалуйста ошибки...

Вычислить произведение элементов массива с четными номерами
Нужно написать 3 задачи на С++. Желательно в самом простом написании. Вот задачи: ЗАДАНИЕ....

8
77 / 77 / 29
Регистрация: 01.08.2009
Сообщений: 177
23.04.2010, 22:33 2
Цитата Сообщение от Jac Посмотреть сообщение
помогите задачу решить(
В одномерном массиве, состоящем из N вещественных элементов, вычислить:
1)произведение элементов массива с четными номерами;
2)сумму элементов массива, расположенных между первым и последним нулевыми элементами.
3)преобразовать массив таким образом, чтобы сначала располагались все положительные элементы, а потом — все отрицательные (элементы, равные нулю, считать положительными).
Если разделить задание на 3 подзадания то 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
#include <iostream>
#include <cstdlib>
#define N 10
using namespace std;
 
int main()
{
    int array[N];
    int product = 1;
    srand(time(NULL));
    //заполняем массив
    for(int i = 0; i < N; i++) 
    {
        array[i] = random() % 10;
        cout << array[i] << " ";
    }
    cout << endl;
    //*************************************************//
    //вычисление произведения четных элементов массива
    for(int i = 0; i < N; i++)
    {
        //cout << product << endl;
        if( (i+1) % 2 == 0 )
            product *= array[i];
    }
    cout << product << endl;
    //*************************************************//
    
    int firstNought = -1, lastNought = -1, summa = 0;
    //нахождение первого нулевого элемента
    for(int i = 0; i < N; i++)
    {
        if(array[i] == 0){
            firstNought = i;
            break;
        }
    }
    //нахождение последнего нулевого элемента
    for(int i = N; i > 0; i--)
    {
        if(array[i] == 0){
            lastNought = i;
            break;
        }
    }
    //нахождение суммы элементов
    for(int i = firstNought; i < lastNought; i++)
    {
        summa += array[i];
    }
    if(firstNought == -1 || lastNought == -1)
        cout << "Нет нулевых элементов";
    else if (firstNought == lastNought)
            cout << "В массиве только один нулевой элемент";
    else cout << summa;
        
    return 0;
}
0
1545 / 911 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
23.04.2010, 22:37 3
Ну дак а вывод массива, тоже не сложно)
Не проверял, но будет как-то так:
Код
C++
1
2
3
4
5
for (int i=0; i<N; i++)
if (MAS[i]>=0) std::cout << std::setw(3) << MAS[i];
 
for (int j=0; j<N; j++)
if (MAS[i]<0) std::cout << std::setw(3) << MAS[i];
0
77 / 77 / 29
Регистрация: 01.08.2009
Сообщений: 177
23.04.2010, 23:02 4
Цитата Сообщение от neske Посмотреть сообщение
Ну дак а вывод массива, тоже не сложно)
Ну дак написано преобразовать массив (т.е отсортировать) а не вывести.. Сложнее чем кажется..
0
Эксперт С++
5037 / 3097 / 271
Регистрация: 11.11.2009
Сообщений: 7,047
23.04.2010, 23:41 5
Считаю "преобразовать" и "отсортировать" разными действиями... Так что если надо именно преобразовать, то думаю так. Заводим два счётчика, первый устанавливаем на первый элемент массива, второй - на последний. Далее двигаем счётчики навстречу друг другу, пока первый не встретит отрицательный элемент, а второй - положительный. Далее меняем эти элементы местами и продолжаем движение. Движемся, пока счётчики не встретятся или не разойдутся.
0
1545 / 911 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
24.04.2010, 07:25 6
Да разные-разные)
Невнимательно я прочитал задание.
0
Peace 2 all shining faces
674 / 535 / 85
Регистрация: 05.03.2010
Сообщений: 1,283
24.04.2010, 09:28 7
как-то так примерно...
C++
1
2
3
4
5
6
7
for(i = 0; i < n; i++)
       if(array[i] < 0){
               tmp = array[i];
               for(j = i; j < n; j++)
                      array[j] = array[j+1];
               array[n-1] = tmp;
       }
встретился отрицательный элемент, мы его значение сразу в сторонку откладываем(в переменную tmp) и сдвигаем массив на 1 символ, а отрицательный элемент потом в конец ставим..
не компилировал, но логически правильно
0
Эксперт С++
5037 / 3097 / 271
Регистрация: 11.11.2009
Сообщений: 7,047
24.04.2010, 17:59 8
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Vorona,
ИМХО, нерационально... Каждый раз передвигать массив... По-моему рациональнее всё-таки искать первый отрицательный и последний положительный элементы и менять их местами...
Т.е. как-то так:

C
1
2
3
4
5
6
7
8
9
10
do
{
        for (i = 0; i < n; i++)
                if (mas[i] < 0) break;
        for (j = n - 1; j >= 0; j--)
                if (mas[j] >= 0) break;
        temp = mas[i];
        mas[i] = mas[j];
        mas[j] = temp;
} while (i <= j);
0
Peace 2 all shining faces
674 / 535 / 85
Регистрация: 05.03.2010
Сообщений: 1,283
25.04.2010, 02:10 9
кому как удобней, думаю массив типа int или long не сможет особо продемонстрировать всю сущность скорости работы алгоритмов и раз на то пошло, то существует итак куча методов чтоб решить эту задачу)
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
25.04.2010, 02:10

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

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

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

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

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


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

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

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