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

сжатие массива

06.04.2009, 10:47. Показов 2913. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
задание:
В одномерном массиве, состоящем из n вещественных элементов, вычислить:
1) Максимальный и минимальный элемент массива
2) Сумму элементов массива, расположенных до последнего положительного эелемента
3)Сжать массив, удалив из него все элементы, модуль которых находиться в интервале [a, b]. Освободившееся в конце массиа элементы заполнить нулями.

проблема: не могу придумать как сделать 3 задание.
помогите пожалуста кто сталкивался с такой задачей !


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 <vcl.h>
#pragma hdrstop
 
#pragma argsused
#include <iostream> 
using std::cout;    
using std::cin; 
using std::endl;    
const size_t MAX = 5;   
int MaxElement(int iArray[])    
{   
    int MaxE = iArray[0];   
    for(size_t i = 1; i < MAX; ++i) 
    {   
        if (iArray[i] > MaxE)   
          MaxE = iArray[i];         
    }   
    return MaxE;
}
 
int MinElement(int iArray[])
{   
    int MinE = iArray[0];   
    for(size_t i = 1; i < MAX; ++i) 
    {   
        if (iArray[i] < MinE)   
          MinE = iArray[i];         
    }   
    return MinE;    
}
 
int SUM(int iArray[])
{
int sum=0;
 int G=0 ;
for (int i=(5-1); i>=0; i--)
{
   if(iArray[i]>=0)
   {
   G=i;
   break;
   }
 
}
   for (int i=0; i<=G; i++)
   {
   sum+=iArray[i] ;
    }
 
    return sum;
}
 
 
int main()  
{   
    int a[MAX]; 
    for(size_t i = 0; i < MAX; ++i) 
    {   
        cout << "Enter next element: "; 
        cin >> a[i];    
        }   
    cout << "Max: " << MaxElement(a) << endl;   
    cout << "Min: " << MinElement(a) << endl;
    cout << "SUM " << SUM(a) << endl;
    char r;
    cin >> r;   
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.04.2009, 10:47
Ответы с готовыми решениями:

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

Сжатие одномерного массива
Написать программу, которая осуществляет сжатие одномерного массива, состоит с N вещественных элементов, и удаляет из него все элементы,...

Поиск слов палиндромов и сжатие массива
Добрый день. Необходимо написать программу, которая будет находить в строке слова-палиндромы, а затем &quot;удалять&quot; из строки слова,...

1
Заблокирован
06.04.2009, 12:14
Вот держи код. Я правда немного подправил твою прогу уж больно необоснованно раздута была, да и с глобальными переменными нужно пороще, так же как и с операциями инкремента и дикремента
++i и i++ - не одно и тоже
Результат работы проги на скриншоте
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
#include <iostream.h>   
#include <math.h>
const size_t NUM = 5;   
 
int MaxElement(int *iArray, int nElements);
int MinElement(int *iArray, int nElements);
int SUM(int *iArray, int nElements);
int RemElements(int *iArray, int nElements, int a, int b);
 
void main()      
{   
    int A,B;
    int a[NUM]; 
    cout << "Enter elements of Array:\r\n"; 
    for(int i = 0; i < NUM; i++)     
    {   
        cout << "a["<<i<<"] = "; 
        cin >> a[i];    
    }       
    cout << "Max: " << MaxElement(a,NUM) << endl;   
    cout << "Min: " << MinElement(a,NUM) << endl;
    cout << "SUM " << SUM(a,NUM) << endl;
    cout<<"Plese enter intervals\r\n";
    cout<<"a : ";
    cin>>A;
    cout<<"b : ";
    cin>>B;
    cout<<"Number of removed elements :"<<RemElements(a,NUM,A,B)<<"\r\n";
    cout<<"Array after replacing elements:\r\n";
    for(i = 0; i < NUM; i++)     
        cout << "a["<<i<<"] = "<<a[i]<<"\r\n";          
    cout<<"Enter 1 to enter other Array\r\n";
    A = 0;cin>>A;
    if(A == 1)
        main();
}
 
int MaxElement(int *iArray, int nElements)    
{       
    int MaxE = iArray[0];       
    for(size_t i = 1; i < nElements; i++)     
    {   
        if (MaxE < iArray[i])   
          MaxE = iArray[i];             
    }   
    return MaxE;
}
 
int MinElement(int *iArray, int nElements)
{       
    int MinE = iArray[0];       
    for(size_t i = 1; i < nElements; i++)     
    {   
        if (iArray[i] < MinE)   
          MinE = iArray[i];             
    }   
    return MinE;        
}
 
int SUM(int *iArray, int nElements)
{
    int sum = 0;
    bool bBegin = false;
    for (int i= nElements - 1; i>=0; i--)
    {
        if(iArray[i]>=0)
            bBegin = true;
        if(bBegin)
            sum += iArray[i];
    }
    return sum;
}
 
int RemElements(int *iArray, int nElements, int a, int b)
{
    int nReplCount = 0;
    int buf,i,j;
    for(j = 0; j < nElements - nReplCount; j++)
    {
        for(i = 0; i < nElements; i++)
        {
            buf = abs(iArray[i]);
            if(a <= buf && buf <= b)
            {
                iArray[i] = 0;
                nReplCount++;
                buf = iArray[nElements - nReplCount];
                iArray[nElements - nReplCount] = iArray[i];
                iArray[i] = buf;
            }
        }
    }
    return nReplCount;
}
Миниатюры
сжатие массива  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.04.2009, 12:14
Помогаю со студенческими работами здесь

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

Написать программу на основе алгоритма RLE (сжатие/восстановление массива)
Массив из 0 и 1 целых чисел. Массив надо сжать, а затем восстановить массива. Надо написать программу по алгоритму RLE. Спасибо заранее ...

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

Описать функцию, которая выполнит сжатие массива(удаление всех чисел меньше 0)
1. Описать функции ввода и вывода элементов массива. Описать функцию, которая выполнит сжатие массива (удаление всех чисел меньше 0). ...

"Сжатие" массива
Натолкнулся на проблему, помогите, пожалуйста разобраться. Допустим у нас есть массив из 100 элементов. Чтобы &quot;сжать&quot; его в...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru