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

Подсчет нулевых элементов в заданном одномерном массиве - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 134, средняя оценка - 4.69
pasha_9090
17 / 17 / 1
Регистрация: 17.11.2010
Сообщений: 84
09.12.2010, 09:21     Подсчет нулевых элементов в заданном одномерном массиве #1
Напишите фрагменты программ для решения следующих задач:

1) подсчет нулевых элементов в заданном одномерном массиве;
2) вычисление суммы положительных элементов в заданном одномерном массиве;
3) поиск первого максимального элемента и его индекса в заданном одномерном массиве;
4) поиск последнего минимального элемента и его индекса в заданном одномерном массиве;
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.12.2010, 09:21     Подсчет нулевых элементов в заданном одномерном массиве
Посмотрите здесь:

C++ kоличество нулевых элементов в заданном целочисленном массиве.
C++ Подсчитать в одномерном массиве количество нулевых значений
C++ записать функцию P,которая в заданном одномерном массиве x элементов типа float,
C++ В одномерном массиве, состоящем из вещественных элементов вычислить номер минимального элемента в массиве, сумму элементов массива
Подсчет количества элементов ,больше суммы предшествующих в одномерном массиве C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MILAN
 Аватар для MILAN
883 / 777 / 86
Регистрация: 21.02.2009
Сообщений: 1,722
09.12.2010, 09:30     Подсчет нулевых элементов в заданном одномерном массиве #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
1,2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
int sum_pol=0
int count=0;
for(int i=0; i<size; i++)
 {
    if(arr[i]==0)
     {
         count++;
     }
    if(arr[i]>0)
     {
         sum_pol+=arr[i];
     }
 }
XuTPbIu_MuHTAu
Эксперт C++
 Аватар для XuTPbIu_MuHTAu
2217 / 732 / 10
Регистрация: 27.05.2008
Сообщений: 1,507
09.12.2010, 09:38     Подсчет нулевых элементов в заданном одномерном массиве #3
Сообщение было отмечено автором темы, экспертом или модератором как ответ
1)

C++
1
2
3
4
5
6
7
8
9
template <class T> 
int numberOf(T * arr, int numberOfElements, T a = 0) { 
int n=0;
for(int i = 0; i < numberOfElements;i++) { 
if(arr[i] == a)
   n++;
}
return n;
}
2)
C++
1
2
3
4
5
6
7
8
int s_pos(int * arr,int n) { 
int s =0;
for(int i = 0;i < n ; i++)  { 
   if(arr[i] > 0) 
      s+=arr[i];
   }
   return s;
}
3)
C++
1
2
3
4
5
6
7
8
template <class T>
int max_ind(T * arr, int numberOfElements) { 
int n = 0;
for( int i =1;i < numberOfElements;i++) { 
    if(arr[i] > arr[n]) n=i;
}
return n;
}
4)
C++
1
2
3
4
5
6
7
8
template <class T> 
int min_ind(T* arr, int numberOfElements) { 
int n=0;
for(int i  = 1;i<numberOfElements;i++) {
   if(arr[i]<=arr[n]) n=i;
}
return n;
}
Там,где есть странное template<class T>, убери эту строку,а в прототипе T* замени на int*.
Sm1t
0 / 0 / 0
Регистрация: 06.09.2011
Сообщений: 17
26.10.2011, 09:44     Подсчет нулевых элементов в заданном одномерном массиве #4
А полностью эти варианты можно где нибудь найти
KATbIK
 Аватар для KATbIK
86 / 81 / 10
Регистрация: 02.08.2011
Сообщений: 335
26.10.2011, 10:33     Подсчет нулевых элементов в заданном одномерном массиве #5
Sm1t, Нее сам доделай ))
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
26.10.2011, 10:47     Подсчет нулевых элементов в заданном одномерном массиве #6
Sm1t,

C++
1
std::vector<int> vec = {1,0,2,0,3,0,1,2,3};
1) подсчет нулевых элементов в заданном одномерном массиве;
C++
1
std::count_if(vec.begin(), vec.end(), [] (const int val) {return !val;});
2) вычисление суммы положительных элементов в заданном одномерном массиве;
C++
1
std::accumulate(vec.begin(), vec.end(), 0, [] (const int first, const int second} {return second > 0 ? first + second : first;});
3) поиск первого максимального элемента и его индекса в заданном одномерном массиве;
C++
1
2
3
std::vector<int>::iterator iter = std::max_element(vec.begin(), vec.end());
std::cout << "Idx: " << iter - vec.begin() << std::endl;
std::cout << "Value: " << *iter << std::endl;
4) поиск последнего минимального элемента и его индекса в заданном одномерном массиве;
C++
1
2
3
std::vector<int>::reverse_iterator iter = std::max_element(vec.rbegin(), vec.rend());
std::cout << "Idx: " << (iter.base() - vec.begin()) - 1 << std::endl;
std::cout << "Value: " << *iter << std::endl;
Sm1t
0 / 0 / 0
Регистрация: 06.09.2011
Сообщений: 17
30.10.2011, 23:48     Подсчет нулевых элементов в заданном одномерном массиве #7
У меня училка со стула е*нется))))))))
Razzeeyy
 Аватар для Razzeeyy
30 / 7 / 2
Регистрация: 01.03.2011
Сообщений: 95
31.10.2011, 01:31     Подсчет нулевых элементов в заданном одномерном массиве #8
ForEveR, а такое есть в стандартной библиотеке О_о блин, даже не знал...

Цитата Сообщение от Sm1t Посмотреть сообщение
У меня училка со стула е*нется))))))))
Что правда, то правда )
Нургали
Сообщений: n/a
25.02.2014, 12:04     Подсчет нулевых элементов в заданном одномерном массиве #9
Дано целое число N и набор из N целых чисел. Найти номер перво-го максимального нечетного числа из данного набора. Если нечетные чис-ла в наборе отсутствуют, то вывести 0.??? помогите,,
Tanhik
0 / 0 / 0
Регистрация: 23.11.2014
Сообщений: 1
23.11.2014, 22:13     Подсчет нулевых элементов в заданном одномерном массиве #10
Нужно найти среднее арифметическое положительных элементов и произведение элементов превышающих среднее арифметическое по абсолютному значению. Ввожу числа -6 4 2 3 -8 , произведение 192. Ввожу -6 4 2 3 - нет элементов . Что не так?
#include "conio.h"
#include "stdio.h"
#include "math.h"

const int n = 25;

void in_ar(int a[], int k)
{
printf("Input %d elements:\n",k);
for(int i=0;i<k;i++)
scanf_s("%d",&a[i]);
}
void out_ar(int a[], int k)
{
for(int i=0;i<k;i++)
{
printf("%d ",a[i]);
}
printf("\n");
}
float sr_ar(int a[],int k)
{
float sr=0,sum=0;
int am=0;
for(int i=0;i<k;i++)
if (a[i]>0)
{
am++;
sum+=a[i];
}
sr=sum/am;
return sr;
}
int pr_ar(int a[],int k,float sr)
{
int pr=1;
for (int i=0;i<k;i++)
if (abs(a[i])>sr)
pr=pr*a[i];
return pr;
}


int main(void)
{
int x[n],k,pr;
float sr;
printf("Input amount of numbers:");
scanf_s("%d",&k);
in_ar(x,k);
printf("Original massive X:\n");
out_ar(x,k);
sr=sr_ar(x,k);
printf("Srednee arifmeticeskoe = %4.2f\n",sr);
pr=pr_ar(x,k,sr);
if (pr!=1) printf("Proizvedenie = %d\n",pr);
else printf("Net elementov");
_getch();
return 0;
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.11.2014, 22:43     Подсчет нулевых элементов в заданном одномерном массиве
Еще ссылки по теме:

Задача на подсчет и вычисление в одномерном массиве с++ C++
C++ Подсчет количества отрицательных элементов в одномерном массиве
Подсчет нулевых символов в массиве C++

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

Или воспользуйтесь поиском по форуму:
-THE_MASTER666-
23.11.2014, 22:43     Подсчет нулевых элементов в заданном одномерном массиве
  #11

Не по теме:

Что за некротроллинг

Yandex
Объявления
23.11.2014, 22:43     Подсчет нулевых элементов в заданном одномерном массиве
Ответ Создать тему
Опции темы

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