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

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [a,b]

15.10.2010, 18:13. Показов 2487. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1.) максимальный элемент массива;
2.) сумму элементов массива, расположенных до последнего положительного элемента.
Сжать массив, удалив из него все элементы, модуль которых находится в интервале [a,b]. Освободившиеся в конце массива элементы заполнить нулями.
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
#include "stdafx.h"
#include <conio.h>
 
int main()
{
    const int N=10;
    int a[N], i, b=0, s=0;
    float c, d;
    printf("vvedite c<d zatem elementi massiva\n");
    
    for (int i = 0; i < N; i++)
        {
            scanf("%f%f%d", &c, &d, &a[i]);
        }
    //поиск максимума
    int max = a[0], indm = 0;
    for (int i = 1; i < N; i++)
        {
            if (max<a[i]) max = a[i];
        }
    //нахождение суммы
    for(i=N-1; i>=0; i--)
        {
            if(a[i]>0) b++;
            if(b>0) s+=a[i];
        }
    //сжатие
    for (int i = 0; i < N; i++)
        {
if(a[i]<c||a[i]>d) a[i+1]=a[i];
printf("sjati massiv\n", a[i]);
        }
printf("MAX= %d, summa= %d", max, s); 
getch();
return 0;
 
}
не могу найти ошибку, помогите
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.10.2010, 18:13
Ответы с готовыми решениями:

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

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [а, b]
В массиве, состоящем из n вещественных элементов, вычислить: - максимальный элемент массива; - сумму элементов массива, расположенных...

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [a,b]
Всем здравствуйте, нужна ваша помощь , написать программу на DEV C++ Очень буду благодарен ! В одномерном массиве, состоящем из n...

6
 Аватар для TheMachinist
246 / 178 / 47
Регистрация: 14.06.2010
Сообщений: 422
15.10.2010, 20:15
У тебя же по условию массив вещественный, а создан целочисленный

поищи по форуму, недавно такая задачка была
0
11 / 11 / 2
Регистрация: 09.10.2010
Сообщений: 23
15.10.2010, 20:16
C++
1
2
3
for (int i = 0; i < N; i++)
    {
        if(a[i]<c||a[i]>d) a[i+1]=a[i];
Тут a[i+1] явно вылазит за пределы массива на последнем шаге цикла.
0
7 / 7 / 0
Регистрация: 25.09.2010
Сообщений: 31
15.10.2010, 22:59  [ТС]
помогите со сжатием.. незнаю как решать((
0
 Аватар для TheMachinist
246 / 178 / 47
Регистрация: 14.06.2010
Сообщений: 422
15.10.2010, 23:44
Обнуляем элементы внутри диапазона и переносим их в конец массива

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 <stdio.h>
#include <conio.h>
#include <algorithm>
 
bool WithinRange(float a, float b, float num) {return num >= a && num <= b;}
bool GreaterThanZero(float num) {return num > 0;}
 
void main()
{   
    const int N =  10;
    float Array[N];
    float a,b;
    for(int i = 0;i < N;++i){
    printf("Enter Array[%d]  ",i);
    scanf("%f",&Array[i]);
    }
 
    printf("Enter Bounds \n");
scanf("%f%f",&a,&b);
for(int i = 0; i < N; ++i){
    if(WithinRange(a, b, Array[i]))
    Array[i] = 0;
    printf("%f  ",Array[i]);
}
 
std::stable_partition(Array, Array+N, GreaterThanZero);
for(int i = 0;i < N; ++i)
printf("%f  ",Array[i]);
 
_getch();
}
1
7 / 7 / 0
Регистрация: 25.09.2010
Сообщений: 31
15.10.2010, 23:54  [ТС]
а можно обойтись без функций?
0
 Аватар для TheMachinist
246 / 178 / 47
Регистрация: 14.06.2010
Сообщений: 422
16.10.2010, 00:32
Все для вас

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 <stdio.h>
#include <conio.h>
 
void main()
{   
    float Array[] = {1,2,3,4,5,6,7,8,9,10};
    float a = 3; float b = 8;
 
    for(int i = 0;i < 10;++i){
        if(Array[i] > a && Array[i] < b)
            Array[i] = 0;
        printf("%f  ",Array[i]);
    }
short flag = 1;
    while(flag)
    {flag = 0;
    for(int i = 0;i < 9;++i){
    if(Array[i] == 0 && Array[i+1] != 0)
    {
        Array[i] = Array[i+1];
        Array[i+1] = 0;
        flag = 1;
    }
    }
    }
    printf("\n\n");
    for(int i = 0; i < 10;++i)
        printf("%f  ",Array[i]);
 
_getch();
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.10.2010, 00:32
Помогаю со студенческими работами здесь

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [a,b]
Сжать массив, удалив из него все элементы, модуль которых находится в интервале . Освободившиеся в конце массива элементы заполнить...

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [a,b].
| Исходные данные - n вещественных величин. || При написании программы используйте динамические массивы. 1. Найти...

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [а, b]
Указатели с++: Задача: В одномерном массиве , состоящем из n действительных элементов , вычислить : • максимальный элемент массива ; ...

Сжать массив, удалив из него все элементы, модуль которых находится в интервале [а, b]
Сжать массив, удалив из него все элементы, модуль которых находится в интервале . Освободившиеся в конце массива элементы заполнить...

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


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение Это мой обзор планшета X220 с точки зрения школьника. Недавно я решила попытаться уменьшить свой. . .
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru