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

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

Войти
Регистрация
Восстановить пароль
 
Kirill Losev
3 / 3 / 0
Регистрация: 01.10.2011
Сообщений: 249
#1

Определить среднюю длину непрерывных участков отрицательных значений элементов массива - C++

06.11.2011, 19:30. Просмотров 466. Ответов 5
Метки нет (Все метки)

в массиве A определить среднюю длину непрерывных участков отрицательных значений элементов

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

Определить среднюю длину слов в предложении - C++
В введенном предложении определить среднюю длину слов в буквах (знаки препинания, числа и другие символы не учитывать)

Сумма значений отрицательных элементов массива - C++
Написать программу, которая выводит сумму значений отрицательных элементов массива, сумму индексов положительных элементов массива и...

Определить количество слов в тексте и среднюю длину слова - C++
Консольное приложение Win32 Текст задачи: Дан текст, в котором слова отделяются пробелами, в конце стоит точка. Определить...

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

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

Произведение суммы значений отрицательных элементов массива, лежащих между min и max, на их количество - C++
Дан массив b0, b1, b2,…, bn-1. Определить произведение суммы значений отрицательных элементов массива, лежащих между элементами с...

5
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
06.11.2011, 20:05 #2
Ну что-нибудь такое:
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
    double res;
    int col=0, sum=0;
    bool fl=false;
    for(int i=0; i<n; i++)
    {
        if(a[i]<0)
        {
            sum++;
            if(!fl)
                fl=true;
        }
        else
        {
            if(fl)
                col++;
            fl=false;
        }
    }
    if(fl)
        col++;
    if(col>0)
        res=(double)sum/col;
    else
        res=.0;
    cout<<res<<endl;
1
Thinker
Эксперт С++
4226 / 2200 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
06.11.2011, 20:11 #3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
double Sred(int *a, int n)
{
    double sum;
    int i, j, k;
    i = k = sum = 0;
    while(i < n)
    {
        while(i < n && a[i] >= 0)
            i++;
        j = i;
        while(i < n && a[i] < 0)
            i++;
        if (j < i)
        {
            k++;
            sum += (i - j);
        }
    }
    return k ? sum/k : -1;
}
0
Kirill Losev
3 / 3 / 0
Регистрация: 01.10.2011
Сообщений: 249
06.11.2011, 21:12  [ТС] #4
Спасибо,
valeriikozlov, все работает, только я не совсем понимаю принцип работы программы. можешь об этом рассказать немного?
0
Thinker
Эксперт С++
4226 / 2200 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
06.11.2011, 21:34 #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
#include <conio.h>
#include <stdio.h>
 
double Sred(int *a, int n)
{
    double sum;
    int i, j, k;
    i = k = sum = 0;
    while(i < n)
    {
        while(i < n && a[i] >= 0)
            i++;
        j = i;
        while(i < n && a[i] < 0)
            i++;
        if (j < i)
        {
            k++;
            sum += (i - j);
        }
    }
    return k ? sum/k : -1;
}
 
int main( )
{
    int a[10] = {1, 2, -1, -2, 2, 3, -2, -3, -2, -1};
    printf ("%f\n", Sred(a, 10));
    getch();
    return 0;
}
0
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
06.11.2011, 21:48 #6
Цитата Сообщение от Kirill Losev Посмотреть сообщение
только я не совсем понимаю принцип работы программы. можешь об этом рассказать немного?
Все просто, подсчитываем общее количество отрицательных элементов в переменной sum, и общее количество непрерывных участков в переменной col (количество участков считаем по количеству окончаний этих участков)
потом наш результат sum/col
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.11.2011, 21:48
Привет! Вот еще темы с ответами:

Определить количество отрицательных элементов массива - C++
5. Определить количество отрицательных элементов

Определить сумму отрицательных элементов массива - C++
Помогите пожалуйста, если кому не трудно, с программой которая : - Создает два массива на N элементов, размер первого определить...

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

Определить количество положительных, отрицательных и нулевых элементов матрицы A(10,15). (Создать три функции для нахождения этих значений) - C++
Определить количество положительных, отрицательных и нулевых элементов матрицы A(10,15). (Создать три функции для нахождения этих...


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

Или воспользуйтесь поиском по форуму:
6
Yandex
Объявления
06.11.2011, 21:48
Ответ Создать тему
Опции темы

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