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

статический массив - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 14, средняя оценка - 4.79
Daniella
0 / 0 / 0
Регистрация: 17.06.2010
Сообщений: 14
23.01.2011, 20:23     статический массив #1
В одномерном статическом массиве состоящем из n вещественных элементов, вычислить:
1) количество элементов массива, больших С;
2) произведение элементов массива, расположенных после максимально по модулю элемента.
Преобразовать массив таким образом, чтобы сначала располагались все отрицательные элементы, а потом все положительные (элементы, равные 0, считать положительными). массив задается генерацией случайных чисел.

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
93
94
95
96
97
98
99
100
101
102
103
104
105
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <string.h>
#include <iomanip>
 
 
using namespace std;
 
const int CHISLO = 8;
int Mas[CHISLO];
int Max = 0;
int proiz = 0;
int k = 0;
int Cas = 0;
int kol = 0;
 
void initRandom();
 
int main()
     {
        cout << " vveidite C ";
        cin >> Cas;
  
     {
        initRandom();
 
        for ( int i = 0; i < CHISLO; i++ )
        {
            Mas[i] = (rand () % 12) - 5;
        }
 
        for ( int i = 0; i < CHISLO; i++ )
        {
            cout << Mas[i] << ends;
            
        }
        cout << endl;
        
        int min = 100;
        int b = 0;
 
// нахождение количества элементов в массиве
 
        for ( int i = 0; i < CHISLO; i++ )
        {
          for( int j = 0; j < i; j++)
            {  
               if  ( Mas[i] < Cas )
                 {
                    kol = kol + kol ;
                 }
            }       
        }
            cout << " Kolichestvo elementov massiva - " << kol << endl; 
    
// произведение элементов в модуле
        
        for( int i = CHISLO-1; i >= 0; i--)
        {
            if Mas[i] > 0 
              {                      
                { 
                    for( int j = 0; j < i; j++)
                    {
                        proiz == Mas[i-1] * Mas[i]  ;
                        
                    }                               
                }                       
            } 
        }
                    cout << " proizvedenie elementov - " << proiz; 
 
// упорядочивание, по  возрастанию 
 
        for( int i = 0;i < CHISLO; i++ )
        {
            for ( int j = i+1; j < CHISLO; j++ )
            {
                if ( Mas[i] > Mas[j])
                {
                    min = Mas[i];
                    Mas[i] = Mas[j];
                    Mas[j] = min;
                }                       
            }
        }
        cout << endl;
        for( int i = 0;i < CHISLO; i++ )
        {   
            cout << Mas[i] << ends;
        }
 
        cout << endl;
 
        cin >> k;
        return 0;
   }
  }
 
 
void initRandom()
    {
        srand((unsigned)time(NULL));
    }
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
NiRamz
23.01.2011, 20:29
  #2

Не по теме:

в чем сам вопрос?

Daniella
0 / 0 / 0
Регистрация: 17.06.2010
Сообщений: 14
23.01.2011, 20:31  [ТС]     статический массив #3
Ну у меня не работает сам код... вроде кажется правильно написано... но видимо где-то пробелы в знаниях языка.
NiRamz
209 / 209 / 16
Регистрация: 26.12.2010
Сообщений: 691
23.01.2011, 20:34     статический массив #4
C++
1
if (Mas[i] > 0)
условие в скобочки забыли взять.
Daniella
0 / 0 / 0
Регистрация: 17.06.2010
Сообщений: 14
23.01.2011, 20:43  [ТС]     статический массив #5
NiRamz, по вашему мнению код написан правильно?
Мне иногда кажется что нет...
NiRamz
209 / 209 / 16
Регистрация: 26.12.2010
Сообщений: 691
23.01.2011, 21:10     статический массив #6
1.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
#include <ctime>
int main()
{
    int c,count=0;
    int mas[10];
    std::cout << "Vvedite C: "<< std::endl;
    std::cin >> c;
    srand(time(NULL));
    for(int i=0;i<sizeof(mas)/sizeof(mas[0]);i++){
        mas[i] = rand()%10;
    }
    for(int i=0;i<sizeof(mas)/sizeof(mas[0]);i++){
        if(mas[i]>c){
            count++;
        }
    }
 
    std::cout << "Vsego elementov v massive > c:" << count << std::endl;
    system("pause");
}
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
#include <iostream>
#include <ctime>
#include <cmath>
int main()
{
    int c,max=0;
    unsigned long proizv;
    int mas[10];
    //std::cout << "Vvedite C: "<< std::endl;
    //std::cin >> c;
    srand(time(NULL));
    for(int i=0;i<sizeof(mas)/sizeof(mas[0]);i++){
        mas[i] = rand()%2+3;
    }
 
    for(int i=0;i<sizeof(mas)/sizeof(mas[0]);i++){
        if(abs(mas[max]) < abs(mas[i])){
            max=i;
        }
    }
 
    for(int i=0;i<sizeof(mas)/sizeof(mas[0]);i++){
        if(i>max){
            proizv *= mas[i];           
        }
    }
    std::cout << "Pos max:" << max << std::endl;
    std::cout << "Proizv:" << proizv << std::endl;
    system("pause");
}
Yandex
Объявления
23.01.2011, 21:10     статический массив
Ответ Создать тему
Опции темы

Текущее время: 10:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru