Форум программистов, компьютерный форум CyberForum.ru

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

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

Изменить порядок следования элементов массива - C++

29.04.2013, 20:15. Просмотров 1075. Ответов 3
Метки нет (Все метки)

В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1) Произведение отрицательных элементов массива;
2) Сумму положительных элементов массива, расположенных до максимального элемента.
Изменить порядок следования элементов в массиве на обратной.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.04.2013, 20:15     Изменить порядок следования элементов массива
Посмотрите здесь:

Изменить порядок следования элементов массива - C++
Прошу помочь буду блогодарна ,заранее спасибо!! Изменить порядок следования элементов массива на противоположный

Изменить порядок следования элементов массива на обратный - C++
Привет всем! Нужна помощь по решению задачи на языке С++. Принципиально я знаю как решать, но не могу никак именно чтобы результат был...

Изменить порядок следования элементов массива на противоположный - C++
Измените порядок следования элементов массива на противоположный.

Изменить порядок следования элементов в массиве - C++
изменить порядок следования элементов в массиве так чтобы сначало располагались все отрицательные элементы за тем положительные а потом...

Изменить порядок следования элементов в массиве на обратный - C++
Здравствуйте. Надо написать функцию, но почему-то он у меня вылетает. Что я неправильно сделал? Вот код функции(сразу хочу извиниться за...

Изменить порядок следования элементов в массиве используя указатели - C++
Вот что есть, почему не работает правильно не понимаю, подскажите плиз) # include <iostream> using namespace std; //7.Пользуясь ...

Изменить порядок следования всех элементов в стеке на противоположный по условию - C++
Реализовать стек, в котором к описанию стека добавлена функция turn, которая меняет порядок следования всех элементов в стеке на...

Если К меньше N, изменить порядок следования элементов в исходном массиве на обратный - C++
Помогите решить эту задачу. Дан массив действительных чисел размером N и целое число К. Если К меньше N, изменить порядок следования...

Изменить порядок следования элементов в массиве на обратный, используя массив указателей - C++
Изменить порядок следования элементов в массиве на обратный, используя массив указателей #include <iostream> #include <iomanip> ...

Описать процедуру, меняющую порядок следования элементов массива - C++
Описать процедуру Invert (A,N), меняющую порядок следования элементов массива A из N вещественных чисел на противоположный...

Реализовать функцию, меняющую порядок следования элементов заданного массива на противоположный - C++
плиз хелп не знаю как подступится Задание - функция, принимает указатель на одномерный массив целых чисел и размер этого массива, и...

Изменить порядок следования слов в строке на обратный - C++
Помогите, пожалуйста, написать функцию, которая изменяет порядок следования слов в строке на обратный


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ded_Vasilij
231 / 213 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
29.04.2013, 21:05     Изменить порядок следования элементов массива #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
const int N = 10;
double A[N] = {0};
int num = 0;
double mul = 1;
double max = A[0];
for(int i = 0; i < N; i++)
{
    cin >> A[i];
    if(A[i] > max)
    {
         max = A[i];
         num = i;
     }
    if(A[i] < 0)
    {
         mul*=A[i];
    }
}
if(num)
{
   double sum = 0;
    for(int i = 0; i < num; i++)
   {
       if(A[i] > 0) {sum+=A[i];}
   }
}
Genn55
360 / 207 / 39
Регистрация: 26.12.2012
Сообщений: 694
29.04.2013, 21:31     Изменить порядок следования элементов массива #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
68
69
70
71
72
73
74
75
76
77
#include <windows.h>
#include <iostream>
#include <stdlib.h>
#include <time.h>
 
//прототип функции для печати массива
void printArray(int[], const int);
 
using namespace std;
 
int main()
{
 SetConsoleCP(1251);
 SetConsoleOutputCP(1251);
 
//объявляем необходимые переменные
const int size = 15;
int massiv[size];
int  sum = 0, proizv = 1,max = 0;
 
//задаем начало отчета для рандомизатора rand()
srand(time(NULL));
 
//наполняем массив случайными величинами
for(int i = 0; i < size; i++)
{
  int  temp = rand()%2;//подсчёт будет минус или нет, если значение будет равно нулю - то число с минусом, в остальных случаях - нет
    if(temp == 0) massiv[i] = (rand() % 100)*-1;
    else massiv[i] = (rand() % 100);//% - означает остаток от деления на 100(от 0 до 99)
 
}
//выводим содержимое массива на экран
cout <<"   Исходный массив" << "\n";
cout <<"\n\n";
printArray(massiv, size);
cout <<"\n\n";
cout <<"   Инвертированный массив" << "\n";
int temp;
 
for(int i = 0; i < size / 2; i++)
{
temp = massiv[i];
massiv[i] = massiv[size - i - 1];
massiv[size - i - 1] = temp;
}
 
printArray(massiv, size);
//выполняем необходимые подсчеты в цикле
for(int i = 0; i < size; i++)
{
if(massiv[i] > max)
max = massiv[i];
if(massiv[i] < 0)
proizv *= massiv[i];
}
for(int i = 0; i < size; i++)
{
if ((massiv[i] > 0)&&(massiv[i] < max))
    sum += massiv[i];
}
cout << "\n\n";
 
cout << "Сумма элементов < max: " << sum << "\n";
cout << "Произведение элементов < 0: " << proizv << "\n";
 
 
return 0;
}
 
//функция вывода массива на экран
void printArray(int a[], const int s)
{
for(int k = 0; k < s; k++)
cout << a[k] << " ";
 
cout << endl;
}
faLek
99 / 100 / 7
Регистрация: 06.03.2012
Сообщений: 478
29.04.2013, 21:50     Изменить порядок следования элементов массива #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
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
#include "stdafx.h"
#include <iostream>
#include <clocale>
#include <ctime>
#include <iomanip>
 
using namespace std;
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    srand (time(NULL));
    setlocale (LC_ALL,"Russian");
 
    const int N = 10;
    int massiv [N];
 
    for (register int i = 0;i<N;i++)
    {
        massiv[i] = -10 + rand () % 21;
            cout<<setw (3)<<massiv[i];
    }
    
    cout<<endl;
    
    int pro = 1,sum= 0;
    int max = massiv[0];
    for (register int i = 0;i<N;i++)
    {
        if (massiv[i]<0)
            pro *= massiv[i];
        if (massiv[i]>max)
            max = massiv[i];
        if ((massiv[i]>0) && (massiv[i]<max))
            sum += massiv[i];
    }
 
    cout<<"Произведение отрицательных: "<<pro;
        cout<<endl;
 
        cout<<"Максимальный элемент: "<<max;
            cout<<endl;
 
    cout<<"Сумма положительных до максимального: "<<sum;
        cout<<endl;
 
        int a = 0;
        for (register int i = 0;i<N/2;i++)
        {
            a = massiv[i];
            massiv[i] = massiv[N - i - 1];
            massiv[N - i - 1] = a;
        }
 
        cout<<"Обратный массив: ";
        for (register int i = 0;i<N;i++)
        {
            cout<<setw (3)<<massiv[i];
        }
 
        cout<<endl;
 
    system ("pause");
    return 0;
Добавлено через 48 секунд
припоздал
Yandex
Объявления
29.04.2013, 21:50     Изменить порядок следования элементов массива
Ответ Создать тему
Опции темы

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