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

Найти сумму модулей элементов массива, расположенных после первого положительного - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ циклы функций isdigit, insert http://www.cyberforum.ru/cpp-beginners/thread193060.html
никак не могу разобраться как дописать следующие функции: int isdigit(char c) { insert(char *s, char c, int i) {
C++ Запись массива в dat файл Хочу записать большой массив в dat файл но получаю ошибку error C2070: int : недопустимый оператор sizeof если делаю массив чуть поменьше то все проходит без ошибок int card_5={0}; FILE *... http://www.cyberforum.ru/cpp-beginners/thread193032.html
C++ сортировка строк текста
этот код выносит мне мозг, разные компиляторы читают его по-разному, ошибка очевидно в функции gets или я ошибаюсь? задачка: вводим с клавиатуры текст в конце каждой строки enter, признаком конца...
C++ Проверить код на корректность
Сделал лабу, все работает отлично.... Но я не уверен что она написана нормально, может где то переменная не там обявляется или не так передается , может функция какая то не так написана... проверте ,...
C++ количество пробелов в двух строках http://www.cyberforum.ru/cpp-beginners/thread192972.html
Здравствуйте. Пожалуйста, помогите кто-нибудь с задачей. Требуется написать программу с классами и объектами которая считает количество пробелов в двух строках, сравнивает их, и выводит сообщение на...
C++ нахождение максимального значение в матрице доброго всем прекрасного время суток.. у меня такой вопрос.. есть ли способ быстро найти елемент с максимальным значением в матрице.. тоесть.. как еще можно найти этот елемент.. не сравнивая... подробнее

Показать сообщение отдельно
kap4enaya
Сообщений: n/a

Найти сумму модулей элементов массива, расположенных после первого положительного - C++

18.11.2010, 00:29. Просмотров 729. Ответов 2
Метки (Все метки)

типичная задачка:
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1. номер максимального по модулю элемента массива;
2. сумму модулей элементов массива, расположенных после первого положительного элемента.
Преобразовать массив таким образом, чтобы сначала располагались все элементы, целая часть которых лежит в интервале , а потом – все остальные.

некорректно работает функция mod, которая должна преобразовать массив.

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
97
98
99
100
#include<cmath>
#include<iostream>
#include<clocale>
#define n 10
using namespace std;
double m[n];
int vvod()
{
    int i=0, a, b;
    cout<<"Введите элементы массива"<<endl;
    do
    {
        cout<<"x["<<i+1<<"]=";
        cin>>m[i];
        cout<<endl;
        i++;
    }
    while (i<n);
    cout<<"a=";
    cin>>a;
    do
    {
        cout<<endl<<"b=";
        cin>>b;
    }
    while (b<=a);
    return a, b;
}
int findmax()
{   
    double max=*m;
    int i, k;
    for (i=0; i<n; i++)
    {
        if (abs(*(m+i))>max)
        {
            max=abs(*(m+i));
            k=i+1;
        }
    }
    return k;
}
double summamod()
{
    int i;
    double sum=0;
    bool flag=true;
    for (i=0; (i<n)&&(flag==true); i++)
    {
        if (*(m+i)>0)
        {
            flag=false;
        }
    }
    do
    {
        sum+=abs(*(m+i));
        i++;
    }
    while (i<n);
    return sum;
}
void mod (double &a, double &b)
{
    int i;
    double dm[n];
    bool flag=true;
    double vr=0;
    dm[i]=*(m+i);
    while (flag==true)
    {
        flag=false;
        for (i=0; i<n; i++)
        {
            if ((dm[i]>=a)&&(dm[i]<=b)) 
            {
                vr=dm[i];
                dm[i]=dm[i+1];
                dm[i+1]=vr;
                flag=true;
            }
        }
    }
 
    for (i=0; i<n; i++)
    {
        cout<<"m["<<i+1<<"]="<<dm[i]<<endl;
    }
}
    
int main ()
{
    double a, b;
    setlocale(LC_ALL, "rus");
    vvod();
    cout<<"наибольший по модулю элемент номер "<<findmax()<<endl;
    cout<<"сумма модулей = "<<summamod()<<endl;
    mod(a, b);
    return 0;
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru