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

Вычислить среднее арифметическое элементов массива - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ вывод значений Enum http://www.cyberforum.ru/cpp-beginners/thread132874.html
вот есть у меня такой enum ColorType { black, white, green, yellow = 13, red, rose = 15 };
C++ zadacha по строкам Какая из гласных букв встречается наибольшее количиство раз в введенной строке. http://www.cyberforum.ru/cpp-beginners/thread132866.html
Обработка символьной информации C++
Помогите решить задачу на С++ Заданный набор ключевых слов, а также текст, в котором хранится длинный список названий книг и научных работ. Выберите названия, содержащие хотя бы одно из заданных ключевых слов.
решите на С или С++ C++
10.55) Написать рекурсивную процедуру перевода натурального числа из десятичной системы счисления в N-ричную.Значения N в основной программе вводится с клавиатуры (2<=N<=16)
C++ Сохранение в графический файл http://www.cyberforum.ru/cpp-beginners/thread132836.html
Здравствуйте дорогие друзья! помогите пожалуйста с задачей. У меня написан текст программы в Dev C++ который рисует график некоторой функции! А как мне полученный рисунок сохранить в файл? Добавлено через 1 час 2 минуты Кто нибудь ответит? помогите новичку =(
C++ Объем и площадь поверхности параллелепипеда.(Функции) Написать функцию, которая вычисляет объем и площадь поверхности параллелепипеда. Объем V=abc, где a,b,c - измерения прямоугольного параллелепипеда; площадь полной поверхности Sп=2(ab+bc+ac). Значения a, b, c вводятся пользователем с клавиатуры. подробнее

Показать сообщение отдельно
Mur3ik
102 / 102 / 4
Регистрация: 12.05.2010
Сообщений: 232
21.05.2010, 14:02     Вычислить среднее арифметическое элементов массива
Цитата Сообщение от Kaziboha Посмотреть сообщение
Задание 3
В одномерном массиве, состоящем из n вещественных элементов, вычислить:

1. сумму элементов массива с нечетными номерами;
2. сумму элементов массива, расположенных между первым и последним отрицательными элементами. Сжать массив, удалив из него все элементы, модуль которых не превышает 1.Освободившиеся в конце массива элементы заполнить нулями.
вот...
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include <iostream>
#include <clocale>
#include <cmath>
#include <cstring>
#include <cstdlib>
#include <ctime>
#include <iomanip>
#include <windows.h>
 
using namespace std;
double sumn(double ar[],int n);
double sumneg(double ar[],int n);
void del(double ar[],int n);
 
void main()
{
    setlocale(LC_CTYPE, "rus");
    const int N=10;
    double arr[N];
    srand(time(NULL));
        for(int i=0;i<N;i++)
        {
        arr[i]=rand()%25-10;
        arr[i]+=(double)(rand()%99)/100;
        }
            for(int i=0;i<N;i++)
            {cout<<arr[i]<<"\t";}
    cout<<endl<<"Сумма нечетных = "<<sumn(arr,N)<<endl;
    cout<<endl<<"Сумма между отрицательными = "<<sumneg(arr,N)<<endl;
    del(arr,N);
        for(int i=0;i<N;i++)
            {cout<<arr[i]<<"\t";}
}
 
 
double sumn(double ar[],int n)
{
    double sum=0;
    for(int i=0;i<n;i++)
    {
        if(i%2!=0)
        {sum+=ar[i];}
    }
    return sum;
}
 
double sumneg(double ar[],int n)
{
double sum=0;
int first=0, last=9;
bool getfirst=false;
    for(int i=0;i<n;i++)
    {
        if(ar[i]<0&&getfirst==false)
        {
        first=i;
        getfirst=true;
        }
        if(ar[i]<0)
        {
        last=i;
        }
    }
    cout<<"Первое отрицательное = "<<first<<" Последнее отрицательное = "<<last;
    for(int i=first+1;i<last;i++)
    {sum+=ar[i];}
    return sum;
 
}
 
void del(double ar[],int n)
{
    double *tmp=new double[n];
    
    int k=0;
    for(int i=0;i<n;i++)
    {
        if(fabs(ar[i])<1)
        {ar[i]=0;}
    }
        for(int i=0;i<n;i++)
        {
            if(ar[i]==0)
            {
                continue;
            }
            tmp[k]=ar[i];
            k++;
        }
        for(int i=0;i<n;i++)
        if(i<k)
        {ar[i]=tmp[i];}
        else
        {ar[i]=0;}
delete tmp;
}
 
Текущее время: 17:06. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru