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

Реализовать «массив целых чисел». Обработать ошибки динамического выделения памяти. Переопределить опе

12.10.2015, 12:14. Показов 4272. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Реализовать класс «массив целых чисел». Обработать ошибки динамического выделения памяти. Переопределить оператор ++ для указателя на массив целых, обработать ошибку выхода за границы массива. Помогите форумчане пожалуйста...
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.10.2015, 12:14
Ответы с готовыми решениями:

Реализовать сортировку динамического массива целых чисел
3)Реализовать сортировку динамического массива целых чисел.

Реализовать многопоточную сортировку динамического массива целых чисел
Есть задание: Написать программу, которая выполняет сортировку динамического массива целых чисел, количество элементов которого...

Функция динамического выделения памяти
Здравствуйте! Никак не получается реализовать функцию динамического выделения памяти и это ставит меня в тупик! #include...

2
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
12.10.2015, 15:05
Что уже сделано, показывай.
"Переопределить оператор ++ для указателя на массив целых" - это как?
0
 Аватар для bogdan_017
21 / 21 / 19
Регистрация: 18.03.2014
Сообщений: 148
12.10.2015, 15:49
Лучший ответ Сообщение было отмечено vikav89 как решение

Решение

vikav89, ты потрясающе везучий(ая), ибо я не так давно писал такую программку в качестве лабы в универе. (среда C++Builder, консольный проект)

main.cpp:
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
//---------------------------------------------------------------------------
#pragma hdrstop
#include "arr.h"
//---------------------------------------------------------------------------
#pragma argsused
int main(int argc, char* argv[])
{
        try {// в блоке try обычное тестирование класса
                A b(5,5);
                b.Print();
 
                b[3]=0;
 
                b++;
 
                b[-1]=4;
 
                b.Print();
            }
 
 
        catch (char *error)
         {
                cerr<<"ATTENTION! "<<error<<endl;
         }
 
        system("pause");
        return 0;
}
arr.h:
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
//---------------------------------------------------------------------------
 
#ifndef arrH
#define arrH
 
#include<iostream.h>
 
class A
{
        public: A();
                A(int, int);    //заполняем числом
 
                ~A()            //деструктор
                        { if (a) delete [] a; a=NULL; }
 
 
                int& operator [] (int n) const //перегрузка оператора
                        { if ((n>=l)||(n<0)) throw ("INCORRECT INDEX"); return a[n]; }
 
 
                A& operator ++ (int);
 
                int GetLength () const { return l;}
                void Print () const;
 
        private:
                int *a;       //указатель на массив
                int l;        //длина
};
//---------------------------------------------------------------------------
#endif
arr.cpp:
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
//---------------------------------------------------------------------------
 
#pragma hdrstop
 
#include "arr.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
A::A():a(0), l(0) {}
 
A::A(int n, int FillNumber)
{
        a=new int[n];
 
        if (!a)        //обрабатываем ошибку динамического выделения памяти
                throw ("FREE STORE EXHAUSTED");
 
        for (int i=0; i<n; i++) // заполняем числом (memset)
                a[i]=FillNumber;
        l=n;
}
 
void A::Print () const
{
        for (int i=0; i<l; i++)
                cout<<a[i]<<" ";
 
        cout<<endl;        
}
 
A& A::operator ++ (int n) 
/*препод сказал перегрузить так, чтобы при вызове оператора 
происходил инкремент всех элементов массива*/
{
        for (int i=0; i<l; i++)
                this->a[i]+=1;
 
        return *this;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.10.2015, 15:49
Помогаю со студенческими работами здесь

По поводу динамического выделения памяти
Допустим, в программе вызывается функция SomeFunc(), описанная как void SomeFunc(){ int arr; //...do something } В...

Применение Динамического выделения памяти
Надо решить задачу написав функцию. Нужно выделить память использую malloc. Помогите Плиз..! Заранее Спасибо)) Дана матрица...

Использование динамического выделения памяти
Найти, сколько элементов массива A={a} удовлетворяют условию а&lt;=с/d. Использовать динамическое выделение памяти.

Функциии динамического выделения и освобождения памяти
Необходим написать функции выделения и освобождения памяти под двумерный динамический массив. Причем освобождение должн быть не сразу для...

Операторы динамического выделения памяти - new/delete
Здравствуйте. Я немного не понимаю некоторый момент, связанный с динамическим выделением памяти, а именно - с объемом выделяемой...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru