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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 9, средняя оценка - 4.67
misterbl95
0 / 0 / 0
Регистрация: 08.12.2011
Сообщений: 22
02.04.2012, 18:39     Массив - количество элементов массива, равных 0 #1
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
а) количество элементов массива, равных 0;
b) сумму элементов массива, расположенных после минимального элемента.


буду благодарен.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Петррр
 Аватар для Петррр
5915 / 3352 / 333
Регистрация: 28.10.2010
Сообщений: 5,926
02.04.2012, 18:48     Массив - количество элементов массива, равных 0 #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;
}
misterbl95
0 / 0 / 0
Регистрация: 08.12.2011
Сообщений: 22
02.04.2012, 18:56  [ТС]     Массив - количество элементов массива, равных 0 #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();
}
Петррр
 Аватар для Петррр
5915 / 3352 / 333
Регистрация: 28.10.2010
Сообщений: 5,926
02.04.2012, 19:08     Массив - количество элементов массива, равных 0 #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;
}
misterbl95
0 / 0 / 0
Регистрация: 08.12.2011
Сообщений: 22
02.04.2012, 19:12  [ТС]     Массив - количество элементов массива, равных 0 #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;
}
ОГРОМНОЕ спасибо
balrak
6 / 6 / 1
Регистрация: 01.04.2012
Сообщений: 81
02.04.2012, 20:19     Массив - количество элементов массива, равных 0 #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 одинаковых минимальных элемонтов
Yandex
Объявления
02.04.2012, 20:19     Массив - количество элементов массива, равных 0
Ответ Создать тему
Опции темы

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