Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
kap4enaya

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

18.11.2010, 00:29. Показов 1691. Ответов 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;
}
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.11.2010, 00:29
Ответы с готовыми решениями:

Найти сумму элементов массива, расположенных после первого положительного элемента
Помогите с лабораторной по массивам. Задание: 1. Исходные данные для всех вариантов - n вещественных величин. 2. При написании...

Найти сумму элементов массива, расположенных после первого положительного элемента
помогите с задачкой просто я несилен в C++ если можно то с объяснениями. Вот собственно и она: В одномерном массиве, состоящем из n...

Найти сумму элементов массива, расположенных после первого положительного элемента
В общем есть задание: Найти сумму элементов массива, расположенных после первого положительного элемента. По моему код написан...

2
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
18.11.2010, 01:55
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 <iostream>
#include <cmath>
 
/*  В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1. номер максимального по модулю элемента массива;
2. сумму модулей элементов массива, расположенных после первого положительного элемента.
Преобразовать массив таким образом, чтобы сначала располагались все элементы, целая часть которых 
лежит в интервале , а потом – все остальные. */
    
// возвращает указатель на максимальный по модулю элемент
double * fabs_max(double * arr, size_t size){
    return ( size == 1 ) ? arr : ( fabs(*arr) > fabs(*(arr + size - 1)) ) ? fabs_max(arr, size - 1) : fabs_max(arr + 1, size - 1);
}
 
// возвращает сумму модулей элементов массива
double fabs_sum(double * arr, size_t size){
    double sum(0.0);
    while ( size-- )
        sum += fabs(*arr++);
    return sum;
}
 
// возвращает true, если целая часть элемента находится в заданном диапазоне
bool in_range(double val, double low, double high){
    val = floor(val);
    return ( val >= low && val <= high );
}
 
// переставляет элементы в массиве. не эффективна при больших размерах массивов,
// за то не использует стандартные классы С++, типичный велосипед
void sort_by_range(double * arr, size_t size, double low, double high){
    double * inRange = new double [ size ];
    double * outRange = new double [ size ];
    size_t cntInRange(0), cntOutRange(0);
    
    for ( size_t i = 0; i < size; ++i ){
        if ( in_range(arr[i], low, high) )
            inRange[cntInRange++] = arr[i];
        else
            outRange[cntOutRange++] = arr[i];
    }
    
    for ( size_t i = 0; i < cntInRange; ++i )
        *arr++ = inRange[i];
    for ( size_t i = 0; i < cntOutRange; ++i )
        *arr++ = outRange[i];
    
    delete [] inRange;
    delete [] outRange;
}
 
// выводит массив
void dump(double * arr, size_t size){
    while ( size-- )
        std::cout << *arr++ << " ";
    std::cout << std::endl;
}
 
int main(){
    double * arr;
    size_t size;
    
    std::cout << "Number of elements: ";
    std::cin >> size;
    arr = new double [ size ];
    for ( size_t i = 0; i < size; ++i ){
        std::cout << "Element #" << ( i + 1 ) << ": ";
        std::cin >> arr[i];
    }
    
    std::cout << "\nYou have entered:" << std::endl;
    dump(arr, size);
    
    double * fabsMax = fabs_max(arr, size);
    std::cout << "Maximum value on the unit " << *fabsMax << " contains an element #" << ( fabsMax - arr + 1 ) << std::endl;
    
    size_t firstPositiveIndex;
    for ( firstPositiveIndex = 0; firstPositiveIndex < size; ++firstPositiveIndex )
        if ( arr[firstPositiveIndex] > 0.0 )
            break;
    if ( firstPositiveIndex == size )
        std::cout << "No positive elements in array." << std::endl;
    else if ( firstPositiveIndex == size - 1 )
        std::cout << "First positive element is last in array." << std::endl;
    else 
        std::cout << "The total of units of elements after first positive is " 
                << fabs_sum(&arr[firstPositiveIndex] + 1, size - firstPositiveIndex - 1) << std::endl;
    
    double low, high;
    std::cout << "Low watermark: ";
    std::cin >> low;
    std::cout << "High watermark: ";
    std::cin >> high;
    sort_by_range(arr, size, low, high);
    std::cout << "Separated by range:" << std::endl;
    dump(arr, size);
    
    delete [] arr;
    return 0;
}
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
18.11.2010, 06:05
kap4enaya, для того что бы функция mod() работала корректно, нужно ей в параметрах передать какие-то 2 значения. А у Вас что ей передается?
У Вас в переменных double a, b нет значений. То что Вы в функции vvod() создавали переменные int a, b (и тип тоже другой) и вводили им значение с клавиатуры - это совсем другие переменные.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.11.2010, 06:05
Помогаю со студенческими работами здесь

Найти сумму элементов массива, расположенных после первого положительного элемента
Здравствуйте, помогите пожалуйста решить задачу на С++ Задание (непрерывные последовательности данных. Одномерные массивы). На языке...

Найти сумму элементов массива, расположенных после первого положительного элемента
В одномерном массиве, состоящем из n вещественных элементов, вычислить: сумму элементов массива, расположенных после первого...

Найти сумму элементов массива, расположенных после первого положительного элемента
Нужна помощь а решении задачи Найти сумму элементов массива, расположенных после первого положительного элемента #include...

Найти сумму и количество элементов массива, расположенных после первого положительного элемента
Добрый день! Подскажите как мне найти количество элементов расположенных после первого положительного элемента. #include...

Найти сумму элементов одномерного массива размером k, расположенных после первого положительного элемента
Память для массива необходимо выделить динамически. Собственно говоря составил какую-никакую программу. При запуске выдаёт ошибку, после...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru