Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.67
misterbl95
0 / 0 / 0
Регистрация: 08.12.2011
Сообщений: 22
#1

Массив - количество элементов массива, равных 0 - C++

02.04.2012, 18:39. Просмотров 1593. Ответов 5
Метки нет (Все метки)

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


буду благодарен.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.04.2012, 18:39
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Массив - количество элементов массива, равных 0 (C++):

Массив: количество элементов массива, равных 0 - C++
10. В одномерном массиве, состоящем из n вещественных элементов, вычислить: а) количество элементов массива, равных 0; b) сумму...

Массив: Посчитать количество элементов массива, равных последнему - C++
В одномерном массиве Y, состоящем из N целых элементов, вычислить: a) количество элементов, равных последнему элементу массива; b)...

Заполнить массив случайными числами; найти количество элементов массива, равных 50, и их индексы - C++
массив из 20 элементов случайные числа от -100 до 100 посчитать сколько элементов равно 50, на каком месте они расположены

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

Количество элементов массива,равных 0 - C++
Прошу помочь буду блогодарна ,заранее спасибо!! Вычеслить количество элементов массива,равных 0

Количество элементов массива, равных 0 - C++
Помоги решить задания, используя динамические массивы. Заранее спасибо! В одномерном массиве, состоящем из n вещественных элементов,...

5
Петррр
5972 / 3409 / 337
Регистрация: 28.10.2010
Сообщений: 5,926
02.04.2012, 18:48 #2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
#include <algorithm>
#include <numeric>
 
int main()
{
    size_t size = 9;
    float array[] = { 0.0, 1.0, 2.0, 3.0, 4.0, 0.0, 4.0, 7.0, 1.0 };
    int zere_count = std::count(array, array + size, 0.0);
    float *min = std::min_element(array, array + size);
    float sum = std::accumulate(min + 1, array + size, 0.0);
    std::cout << "Zero elements: " << zere_count << std::endl <<
        "Sum after max element: " << sum << std::endl;
    system("pause");
    return 0;
}
1
misterbl95
0 / 0 / 0
Регистрация: 08.12.2011
Сообщений: 22
02.04.2012, 18:56  [ТС] #3
Цитата Сообщение от Петррр Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
#include <algorithm>
#include <numeric>
 
int main()
{
    size_t size = 9;
    float array[] = { 0.0, 1.0, 2.0, 3.0, 4.0, 0.0, 4.0, 7.0, 1.0 };
    int zere_count = std::count(array, array + size, 0.0);
    float *max = std::max_element(array, array + size);
    float sum = std::accumulate(max + 1, array + size, 0.0);
    std::cout << "Zero elements: " << zere_count << std::endl <<
        "Sum after max element: " << sum << std::endl;
    system("pause");
    return 0;
}
Спасибо конечно большое ахах)
попытаюсь поковыряться просто с массивами еще с паскаля проблемы просто у нас выглядет немного все по другому еще и привяжутся же

Добавлено через 57 секунд
Просто смотрю на другие простые задания с конспекта все так просто выглядит

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
#include<iostream.h>
#include<conio.h>
#include<stdlib.h>
void main()
{  int i,k=0,k1=0,j,n;   
   randomize();
   clrscr();
   float s=0,x[50],a;        
   cout<<"\nВведите  n = ";
   cin>>n;
   for(i=0; i<n; i++)
   {  x[i]=(random(15)-5)/2.;
      cout<<"  "<<x[i];
   }
   for(i=0; i<n; i++)
      if(x[i]>0) k++;
   cout<<"\nКоличество положительных элементов массива k = "<<k;
 
 
   for(i=n-1; i>=0; i--)
   {  if(k1==0)  s+=x[i];
      if(x[i]==0) k1++;
   }
   cout<<"\nСумма после последнего нуля s = "<<s;
 
 
   for(i=0; i<n-1; i++)
      for(j=0; j<n-i-1; j++)
     if(x[j]>=2)
     {  a=x[j];
        x[j]=x[j+1];
        x[j+1]=a;
     }
   cout<<"\nПреобразованный массив: ";
   for(i=0; i<n; i++)
      cout<<"  "<<x[i];
   getch();
}
0
Петррр
5972 / 3409 / 337
Регистрация: 28.10.2010
Сообщений: 5,926
02.04.2012, 19:08 #4
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
#include <stdio.h>
#include <stdlib.h>
 
int count(float *first, float *last, float value)
{
    int c = 0;
    while (first != last)
        if (*first++ == value)
            c++;
    return c;
}
 
float *min_element(float *first, float *last)
{
    float *min = first;
    while (++first != last)
        if (*first < *min)
            min = first;
    return min;
}
 
float sum(float *first, float *last, float b)
{
    float s = b;
    while (first != last)
        s += *first++;
    return s;
}
 
int main(void)
{
    size_t size = 9;
    float array[] = { 0.0, 1.0, 2.0, 3.0, 4.0, 0.0, 4.0, 7.0, 1.0 };
    int zere_count = count(array, array + size, 0.0);
    float *min = min_element(array, array + size);
    printf("Zero elements: %d\n", zere_count);
    printf("Sum after min element: %.3f\n", sum(min + 1, array + size, 0.0));
    system("pause");
    return 0;
}
1
misterbl95
0 / 0 / 0
Регистрация: 08.12.2011
Сообщений: 22
02.04.2012, 19:12  [ТС] #5
Цитата Сообщение от Петррр Посмотреть сообщение
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
#include <stdio.h>
#include <stdlib.h>
 
int count(float *first, float *last, float value)
{
    int c = 0;
    while (first != last)
        if (*first++ == value)
            c++;
    return c;
}
 
float *min_element(float *first, float *last)
{
    float *min = first;
    while (++first != last)
        if (*first < *min)
            min = first;
    return min;
}
 
float sum(float *first, float *last, float b)
{
    float s = b;
    while (first != last)
        s += *first++;
    return s;
}
 
int main(void)
{
    size_t size = 9;
    float array[] = { 0.0, 1.0, 2.0, 3.0, 4.0, 0.0, 4.0, 7.0, 1.0 };
    int zere_count = count(array, array + size, 0.0);
    float *min = min_element(array, array + size);
    printf("Zero elements: %d\n", zere_count);
    printf("Sum after min element: %.3f\n", sum(min + 1, array + size, 0.0));
    system("pause");
    return 0;
}
ОГРОМНОЕ спасибо
0
balrak
6 / 6 / 1
Регистрация: 01.04.2012
Сообщений: 81
02.04.2012, 20:19 #6
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
#include <iostream>
 
int find_m(const float* mass, const int leng); 
 
int main()
{
   std::cout << "Enter mass length " << std::endl;
   static int leng, zero = 0;
   static float counter = 0;
   std::cin >> leng;
   std::cout << "Enter ur mass" << std::endl;
   float* mass = new float[leng];
   for (int i = 0;i < leng; i++)
   {
       std::cin >> mass[i];
       if (mass[i] == 0)
           zero++;
   }
   for (int i = find_m(mass, leng); i < leng; i++)
       counter += mass[i];
   std::cout << "Zero counter = " << zero << std::endl;
   std::cout << "Counter = " << counter << std::endl;
}
 
int find_m(const float* mass, const int leng)
{
    static int p = 0;
    for (int i = 1; i < leng; i++)
    {
        if (mass[i] < mass[p])
            p = i;
    }
    return ++p;
}
Мой вариант
вот только не уверен как надо было поступить если в масиве 2 одинаковых минимальных элемонтов
0
02.04.2012, 20:19
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.04.2012, 20:19
Привет! Вот еще темы с ответами:

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

Найти количество элементов массива, равных 0 - C++
Хлопцы патрэбна дапамога!Буду вельмі ўдзячны!:) Условие:При написании программ использовать динамические массивы. Размерность массивов...

Вычислить количество элементов массива, равных 0 - C++
В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1. количество элементов массива, равных 0; 2. ...

Вычислить количество элементов массива, равных 0 - C++
В массиве, состоящем из n вещественных чисел, необходимо вычислить:- количество элементов массива, равных 0;- сумму элементов массива,...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

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