Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 06.08.2009
Сообщений: 80

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

19.05.2011, 18:51. Показов 611. Ответов 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; 
}
}
нужно исправить так, чтобы когда массив сортируется, то не новый массив через рэндом делался, а который уже есть.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.05.2011, 18:51
Ответы с готовыми решениями:

количество четных элементов одномерного массива до числа равному а, Определить количество нечетных элементов двумерного массива
1.Найти количество четных элементов одномерного массива до первого встреченного числа равного наперед заданному числу а. 2.Дан двумерный...

Записать положительные элементы массива X подряд в массив Y. Определить k – количество положительных элементов. Вычислит сумму элементов массива Y
Записать положительные элементы массива X=(x1,x2,…, xn) подряд в массив Y=(y1,y2,…, yk). Определить k – количество положительных...

Вычислить количество положительных элементов массива и сумму элементов массива, расположенных после последнего элемента, равного нулю
В одномерном массиве, состоящем из n вещественных элементов, вычислить: количество положительных элементов массива; сумму элементов...

1
152 / 150 / 44
Регистрация: 09.02.2010
Сообщений: 407
19.05.2011, 19:07
лисыч,

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;
}
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.05.2011, 19:07
Помогаю со студенческими работами здесь

Подсчитать количество элементов одномерного массива, которые превосходят среднее арифметическое всех элементов массива
Подсчитать количество элементов одномерного массива, которые превосходят среднее арифметическое всех элементов массива.

Определить количество элементов массива, меньших среднего арифметиче-ского значений элементов этого массива
Времени нет , только ещё учу . нужно сделать срочно работы . углубился в учебник пока , но не успеваю разобраться . может есть...

Вернуть количество элементов массива, которые больше среднего значения всех элементов данного массива
Написать функцию, которая возвращает количество элементов массива, которые больше среднего значения всех элементов данного массива.

Вычислить: количество минимальных элементов массива и сумму элементов массива, расположенных до первого минимума
В одномерном целочисленном массиве (размер массива не больше 20 и значения его элементов вводить с клавиатуры) вычислить:количество...

Одномерные массивы и указатели (найти количество элементов массива, равных 0, сумму элементов массива...)
Помогите пожалуйста разработать программу и реализовать интуитивный понятный интерфейс (используя формы).При написании программы можно...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru