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

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

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

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

19.05.2011, 18:51. Просмотров 309. Ответов 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++ Количество элементов массива
C++ Количество элементов массива
Найти количество нулей среди элементов массива, расположенных между минимальным и максимальным элементом массива. C++
C++ Найти номера тех элементов массива, которые больше своего правого соседа, и количество таких элементов
Массив и функция (количество нечетных элементов массива, минимальный из элементов и его номер) C++
Создать массив С какой складываться из нечетных чисел массива А, посчитать количество элементов массива С C++
C++ Вычислить количество элементов массива целых M [15] больших квадрата первого элемента этого массива
C++ Как скопировать одну половину массива (количество элементов массива четноё) в другую?
C++ Найти количество элементов массива, не превосходящих среднее значение элементов на главной диагонали
Найти среднее арифметическое элементов массива, и количество чисел внутри массива, не превышающих найденное C++
C++ Найти количество элементов массива, каждый из которых меньше по значению, чем среднее среди элементов
C++ В одномерном массиве, состоящим из n вещественных элементов вычислить количество элементов массива, больших С

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
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;
}
Yandex
Объявления
19.05.2011, 19:07     Количество элементов массива
Ответ Создать тему
Опции темы

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