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

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

Войти
Регистрация
Восстановить пароль
 
лисыч
0 / 0 / 0
Регистрация: 06.08.2009
Сообщений: 80
#1

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

19.05.2011, 18:51. Просмотров 315. Ответов 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     Количество элементов массива
Посмотрите здесь:

Создать два массива. Вычислить количество тех элементов каждого массива, для которых выполняется неравенство: 2<элемент массива<10 - C++
помогите,пожалуйста! есть вот такие задания...ОЧЕНЬ надо на завтра... Задача 4. Определить два одномерных массива А(19) и В(16);...

Найти количество отрицательных элементов массива, находящихся во второй половине массива - C++
Обязательные условия: 1) массивы должны быть динамические – организовать выделение памяти; 2) значения элементов массива вводятся с ...

Найти количество элементов в этих массива равных первому элементу массива S - C++
Даны целочисленные массивы S и T с разным количеством элементов. Найти количество элементов в этих массива равных первому элементу массива...

Как скопировать одну половину массива (количество элементов массива четноё) в другую? - C++
Допустим, есть массив с чётным количеством элементов. Каким образом я могу скопировать первую половину массива (то есть первые 5 элементов)...

Найти количество элементов массива, не превосходящих среднее значение элементов на главной диагонали - C++
Добрый день. Имеется двумерный массив, представленный квадратной матрицей NxN. В ней нужно найти количество элементов, не превосходящих...

Массив и функция (количество нечетных элементов массива, минимальный из элементов и его номер) - C++
Кто добр в душе и может помочь,очень прошу-не откажите девушке!!! Целочисленный массив из N элементов заполнить случайными значениями...

Вычислить количество элементов массива целых M [15] больших квадрата первого элемента этого массива - C++
Помогите пожалуйста решить. Вычислить количество элементов массива целых M больших квадрата первого элемента этого массива. Вывести массив

Найти среднее арифметическое элементов массива, и количество чисел внутри массива, не превышающих найденное - C++
Напишите пожалуйста код на С++ по этой задаче: Найти среднее арифметическое всех элементов массива и посчитать количество чисел внутри...

Массив. Найти количество элементов, меньших среднего арифметического положительных элементов этого массива - C++
Всем привет! Пмогите пожалуйста написать программу! Массив a(30) сформирован случайным образом. Найти в нем количество элементов, меньших...

Количество элементов массива - C++
У меня есть функция, в которой я создаю массив char. Мне нужно сделать так, чтобы кол-во элементов массива зависело от значения другой...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
dampir_sanek
150 / 148 / 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;
}
Ответ Создать тему
Опции темы

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