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

Заменить все элементы, модуль которых не превышает 1, на 1

26.12.2021, 21:25. Показов 868. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! В лабе одно из заданий заменить все элементы, модуль которых не превышает 1, на 1. Изначально это мне казалось простой задачей, но я столкнулся с ошибкой которую уже больше недели не могу исправить. Я выяснил что ошибка в программе происходит во время выполнения этой задачи, но как исправить понять к сожалению не могу.
Код замены модуля
C++
1
2
3
4
5
6
7
8
9
10
11
    float *massiv2 = new float [size];
    for(int i=0; i<size; i++){
    if(abs(massiv[i])>=1)
        massiv2[j++]=massiv[i];
    }
    for(int i=0; i<size; i++){
        massiv2[j++]=1;
    }
    cout<<"modul` ";
    for(int i=0; i<size; i++)
    cout<<massiv2[j]<<' ';
Полный код программы и полное задание
Кликните здесь для просмотра всего текста
В одномерном массиве, состоящем из N вещественных элементов, вычислить:
1) сумму элементов массива с нечетными номерами;
2) сумму элементов массива, расположенных между первым и последним отрицательными элементами.
Заменить все элементы, модуль которых не превышает 1, на 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
#include <iostream>
#include <iomanip>
#include <cmath>
using namespace std;
int main(){
int size, j=0, first, last;
    cout<<"Vvedite kolichestvo elementov\n";
    cin>>size;
    float *massiv = new float [size];
    cout<<"Vvedite massiv iz"<<' '<<size<<' '<<"elemetov\n";
    for(int i=0; i<size; i++)
    cin>>massiv[i];
    cout<<"ishodniy ";
    for(int i=0; i<size; i++)
    cout<<massiv[i]<<' ';
 
    //вычисление суммы нечетных элементов
    double OddSum=0;
        for (int i=0; i<size;i++){ 
        if(i%2==0) OddSum += massiv[i]; 
        }
    cout<<"\nSumma ne chetnix = "<<OddSum<<endl;  
    
    //вычисление суммы между отрицательными элементами
    float NegativeSum=0;
    for( first = 0; first < size; first++ ) {
        if( massiv[first] < 0 ) break;
    }
    for( last = size-1; last > first; last-- ) {
        if( massiv[last] < 0 ) break;
    }
    for(int i = first+1; i < last; i++ ) {
        NegativeSum += massiv[i];
    }
    cout<<"Summa mezhdu otric[i] = "<<NegativeSum<<endl;
 
    //замена элементов модуль которых не превышает 1, на 1
    float *massiv2 = new float [size];
    for(int i=0; i<size; i++){
    if(abs(massiv[i])>=1)
        massiv2[j++]=massiv[i];
    }
    for(int i=0; i<size; i++){
        massiv2[j++]=1;
    }
    cout<<"modul` ";
    for(int i=0; i<size; i++)
    cout<<massiv2[j]<<' ';
 
    //сортировка массива
    int length = size;
    for (int startI = 0; startI < length - 1; ++startI) {
            int smallestI = startI;
            for (int currentI = startI + 1; currentI < length; ++currentI) {
                if (massiv2[currentI] < massiv2[smallestI])
                smallestI = currentI;
            }
            swap(massiv2[startI], massiv2[smallestI]);
        }
    cout<<"\nsorted ";
    for (int i=0; i < length; ++i)
    cout << massiv2[j]<<' ';
 
delete [] massiv;
delete [] massiv2;
return 0;
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.12.2021, 21:25
Ответы с готовыми решениями:

Расположить в начале массива все элементы, модуль которых не превышает 8, а потом - все остальные
Создать одномерный массив, состоящий из n вещественных элементов. Элементы массива определить при помощи случайных чисел в диапазоне от -18...

В заданном массиве расположить все элементы, модуль которых не превышает 1, а потом – все остальные
Проверьте пж мой код, не пойму где ошибки: #include &lt;iostream&gt; //вот задание:С одномерным массивом, состоящим из n вещественных...

Удалить из массива все элементы, модуль которых не превышает 1
Здравствуйте! Началась сессия. А у меня &quot;Спасите-помогите&quot;. Пожалуйста. У меня проблема. Есть задание. Вот оно. Создайте динамический...

1
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
27.12.2021, 00:39
Лучший ответ Сообщение было отмечено cragobor как решение

Решение

cragobor, забывайте про float, применяйте double

В одномерном массиве, состоящем из N вещественных элементов заменить все элементы, модуль которых не превышает 1, на 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
#include <iostream>
#include <cmath>
using namespace std;
 
int main()
{
    int N;
    cout << "N="; cin >> N;
    
        double *a = new double[N];
    
    cout << "Enter " << N << " numbers:\n";    
    for(int i = 0; i < N; i++)
        cin >> a[i];    
        
    for(int i = 0; i < N; i++)
    {
        if(fabs(a[i])<=1.) a[i]=1.;
        cout << a[i] << " ";
    }
    cout << "\n";
    
return 0;
}
не по теме вопроса:
// вычисление суммы нечетных элементов элементов с нечётными номерами
C++
1
2
3
double sum=0.;
for (int i = 0; i < N; i+=2) 
    sum+=a[i];
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.12.2021, 00:39
Помогаю со студенческими работами здесь

Сжать массив, удалив из него все элементы модуль которых не превышает 1. Заполнить эти элементы нулями
Во время перестановки, когда первый 0 достигает конца массива, выскакивает ошибка и прога останавливается. При этом на последнем элементе...

В начале массива расположить все элементы, модуль которых не превышает 1, а после них - все остальные
Ребят, помогите, пожалуйста! Нужно написать программу в С++ для решения задачи: Превратите массив таким образом, чтобы в начале...

Преобразовать массив, чтобы сначала шли все элементы, модуль которых не превышает 1, а затем все остальные
Доброго времени суток! Вот моя задача: В одномерном массиве, который состоит з n действительных элементов, найти: 1. номер...

Сжать массив, удалив из него все элементы, модуль которых не превышает 1
Дан целочисленный массив размера N. Сжать массив, удалив из него все элементы, модуль которых не превышает 1.

Сжать массив, удалив из него все элементы, модуль которых не превышает 1.
В одномерном массиве, состоящем из 20 вещественных элементов, вычислить: 1) сумму элементов массива с нечетными номерами; 2) сумму...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru