Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на C / C++


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный ХОСТИНГ на базе Linux x64 и Windows x64

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Лучшие эксперты по данной тематике

Асмик Гаряка
Статус: Советник
Рейтинг: 11066
∙ повысить рейтинг »
Коцюрбенко Алексей aka Жерар
Статус: Советник
Рейтинг: 4118
∙ повысить рейтинг »
CradleA
Статус: Бакалавр
Рейтинг: 2196
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И СОФТ / Программирование / C/C++

Номер выпуска:1772
Дата выхода:27.12.2012, 18:00
Администратор рассылки:Киселёва Алёна aka Verena (Академик)
Подписчиков / экспертов:100 / 68
Вопросов / ответов:1 / 1

Консультация # 187041: Здравствуйте! Прошу помощи в следующем вопросе: во вложении задание. Сделал все, кроме 3 пункта. Осталось задать память динамически, создать копирующий конструктор и переопределить экземпляр класса. ...


Консультация # 187041:

Здравствуйте! Прошу помощи в следующем вопросе:
во вложении задание. Сделал все, кроме 3 пункта. Осталось задать память динамически, создать копирующий конструктор и переопределить экземпляр класса.

Дата отправки: 24.12.2012, 13:45
Вопрос задал: Соловьев (Посетитель)
Всего ответов: 1
Страница онлайн-консультации »


Консультирует Киселёва Алёна aka Verena (Академик):

Здравствуйте, Соловьев!
Изменений немного. В самом описании класса:

Код :
class alphabet {
private: 
	int n;
	char *c;
	void IncSize (int size); //увеличивает размер массива на заданное значение
	 public:
		alphabet();
		alphabet(const alphabet&); //конструктор копирования
		alphabet(int,int);
		alphabet(char*);
	friend istream& operator>>(istream& in,alphabet& p);
	friend ostream& operator<<(ostream& on,alphabet& p);
	alphabet& operator+(alphabet&);
	alphabet& operator+=(char);
	alphabet operator= (const alphabet& a); //оператор присваивания
	char* cipher(char*,int);
	char* decipher(char*,int);
	int check (char);
	int checkall(char*);
	int over();
	};

И вот в этих функциях:
Код :
alphabet::alphabet(){n=0;c=NULL;}

 alphabet::alphabet(int c0,int k){int i;
	n=k;
	c = new char [n+1]; //выделяем память
	for(i=0;i<n;i++)c[i]=c0+i;c[n]=0;}

 alphabet::alphabet(char* s){int i;n=strlen(s);
 c = new char [n+1];//выделяем память

	strcpy(c,s);}
alphabet& alphabet:: operator+(alphabet& b){
	IncSize (b.n);
	strcat(c,b.c);
	return *this;}

alphabet& alphabet::operator+=(char s){
	if(check(s)){cout<<"Symbol Alredy Exists,";return *this;}
	IncSize (1);
	c[n]=s;c[n+1]=0;
	return *this;}

И новые функции:
Код :
alphabet::alphabet(const alphabet& a)
{
	n = a.n;
	if (n>0) {
		c = new char [n+1];
		strcpy (c, a.c);
	}
	else c = NULL;

}

alphabet alphabet::operator= (const alphabet& a)
{
	if (n>0) delete [] c;
	n = a.n;
	if (n>0) {
		c = new char [n+1];
		strcpy (c, a.c);
	}
	else c = NULL;
	return *this;
}

void alphabet::IncSize (int size)
 {
	 n+=size;
	 char *tmp = new char [n+1];
	 strcpy (tmp, c);
	 delete [] c;
	 c = new char [n+1];
	 strcpy (c, tmp);
	 delete [] tmp;
	 c[n] = 0;
 }

Кроме того, не помещает описать деструктор:
Код :
alphabet::~alphabet ()
 {
	 if (n>0) delete [] c;
 }


Удачи!

Консультировал: Киселёва Алёна aka Verena (Академик)
Дата отправки: 26.12.2012, 19:33

5
нет комментария
-----
Дата оценки: 27.12.2012, 09:03

Рейтинг ответа:

НЕ одобряю 0 одобряю!


Оценить выпуск | Задать вопрос экспертам

главная страница  |  стать участником  |  получить консультацию
техническая поддержка  |  восстановить логин/пароль

Дорогой читатель!
Команда портала RFPRO.RU благодарит Вас за то, что Вы пользуетесь нашими услугами. Вы только что прочли очередной выпуск рассылки. Мы старались. Пожалуйста, оцените его. Если совет помог Вам, если Вам понравился ответ, Вы можете поблагодарить автора - для этого в каждом ответе есть специальные ссылки. Вы можете оставить отзыв о работе портале. Нам очень важно знать Ваше мнение. Вы можете поближе познакомиться с жизнью портала, посетив наш форум, почитав журнал, который издают наши эксперты. Если у Вас есть желание помочь людям, поделиться своими знаниями, Вы можете зарегистрироваться экспертом. Заходите - у нас интересно!
МЫ РАБОТАЕМ ДЛЯ ВАС!



В избранное