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

Количество элементов массива - C++

Восстановить пароль Регистрация
 
лисыч
0 / 0 / 0
Регистрация: 06.08.2009
Сообщений: 80
19.05.2011, 18:51     Количество элементов массива #1
Задача :в одномерном массиве, состоящем из n вещественных элементов, вычислить:
1) количество элементов массива, меньших 0;
2) сумму целых частей элементов массива, расположенных после последнего отрицательного элемента.
Преобразовать массив таким образом, чтобы сначала располагались все элементы, отличающиеся от максимального не более чем на 20%, а потом - все остальные.

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
#include <stdio.h> 
#include <stdlib.h> 
#include <conio.h> 
#include <time.h> 
 float x[100];
int main(int argc, char *argv[]) 
{ 
  float c, a, s1, sp, otr_element, max_element; 
  int i, imin, n, b, p, k, s; 
  printf("Vvedite kolichestvo el-tov massiva: "); 
    scanf("%d",&n); 
  for(i = 0; i < n; i++) 
        x[i] = ((float)rand()/RAND_MAX)*20 - 10; 
  for(i = 0; i < n; i++) 
        printf("x[%d] = %7.4f\n",i,x[i]); 
  printf("\n\nVvedite C: "); 
  scanf("%f",&c); 
  for(i = 0, p = 0; i < n; i++) { 
        if(x[i] < c) p++;       
  } 
  printf("1) Kolichestvo elementov masiva menshe C ravno %d\n\n",p); 
  getch(); 
  for(i = 0; i < n; i++) 
  if(x[i] < 0) imin = i;      
  for(s=0; i<n; i++)   
  s += (int)x[i]; 
  for(i = imin + 1, s = 0.0; i < n; i++) 
  s += (int)(x[i]); 
  printf("2) Summa chelih chastei, posle poslednego otr. elementa = %d\n\n",s); 
  getch(); 
  max_element = x[0]; 
  for(i = 1; i < n; i++) { 
        if(x[i] > max_element) max_element = x[i];       
}
  for(i = 0; i < n; i++) { 
       if((x[i] >= s1)&&(x[i] <= max_element)) { 
                for(k = 0; k < n; k++) { 
                      if(x[i] > x[k]) { 
                             a = x[i]; 
                             x[i] = x[k]; 
                             x[k] = a;         
                      }          
                } 
       }       
  printf("Posle sortirovki elementov\n"); 
  for(i = 0; i < n; i++) 
        x[i] = ((float)rand()/RAND_MAX)*20 - 10; 
  for(i = 0; i < n; i++) 
        printf("x[%d] = %7.4f\n",i,x[i]);     
  return 0; 
}
}
нужно исправить так, чтобы когда массив сортируется, то не новый массив через рэндом делался, а который уже есть.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.05.2011, 18:51     Количество элементов массива
Посмотрите здесь:

C++ Создать два массива. Вычислить количество тех элементов каждого массива, для которых выполняется неравенство: 2<элемент массива<10
Записать положительные элементы массива X подряд в массив Y. Определить k – количество положительных элементов. Вычислит сумму элементов массива Y C++
C++ Одномерные массивы и указатели (найти количество элементов массива, равных 0, сумму элементов массива...)
C++ В одномерном массиве, вычислить: а) количество элементов массива б) произведение элементов массива в) От - к +
Определить количество элементов массива, меньших среднего арифметиче-ского значений элементов этого массива C++
C++ количество четных элементов одномерного массива до числа равному а, Определить количество нечетных элементов двумерного массива
C++ Найти через индекс количество отрицательных и количество положительных элементов массива
C++ Определить сумму указанных элементов, количество нечетных элементов и среднее арифметическое четных элементов массива

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
dampir_sanek
149 / 147 / 21
Регистрация: 09.02.2010
Сообщений: 407
19.05.2011, 19:07     Количество элементов массива #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
59
60
61
62
#include <stdio.h>
#include <stdlib.h>
 
#include <time.h>
 
float x[100];
int main(int argc, char *argv[])
{
    float c, a, s1, max_element;
    int i, imin, n, p, k, s;
    srand( (unsigned int) time(NULL));
    printf("Vvedite kolichestvo el-tov massiva: ");
    scanf("%d",&n);
    float *x;
    x = (float*) malloc(n*sizeof(float));
 
    for(i = 0; i < n; i++)
        x[i] = ((float)rand()/RAND_MAX)*20 - 10;
    for(i = 0; i < n; i++)
        printf("x[%d] = %7.4f\n", i, x[i]);
 
    printf("\n\nVvedite C: ");
    scanf("%f",&c);
    for(i = 0, p = 0; i < n; i++)
        if (x[i] < c) p++;
 
    printf("1) Kolichestvo elementov masiva menshe C ravno %d\n\n",p);
    getchar();
    for(i = 0; i < n; i++)
        if(x[i] < 0) imin = i;
    for(s=0; i<n; i++)
        s += (int)x[i];
    for(i = imin + 1, s = 0.0; i < n; i++)
        s += (int)x[i];
    printf("2) Summa chelih chastei, posle poslednego otr. elementa = %d\n\n",s);
    getchar();
 
    max_element = x[0];
    for(i = 1; i < n; i++)
        if(x[i] > max_element) max_element = x[i];
   
    for(i = 0; i < n; i++)
    {
        if((x[i] >= s1)&&(x[i] <= max_element))
        {
            for(k = 0; k < n; k++)
            {
                if(x[i] > x[k])
                {
                    a = x[i];
                    x[i] = x[k];
                    x[k] = a;
                }
            }
        }
        printf("Posle sortirovki elementov\n");
 
        for(i = 0; i < n; i++)
            printf("x[%d] = %7.4f\n",i,x[i]);
    }
    return 0;
}
Yandex
Объявления
19.05.2011, 19:07     Количество элементов массива
Ответ Создать тему
Опции темы

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