Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Листинг списков





class shiplist

{

public:

 

struct ship //элемент списка

{

int x,y;

ship* nextright;

ship* nextdown;

 

ship(int _x, int _y, ship *nr = NULL, ship *nd = NULL)// конструктор с передающ значениями

{

x = _x;

y = _y;

nextright = nr;

nextdown = nd;

}

};

 

int shipCount;

ship* first; // Первый элемент

ship* firstdown; //Верхний элемент

ship* lastright; //Последний элемент в списке корабля

ship* lastdown;// Последний элемент в списке кораблей

 

shiplist() // Конструктор списка

 

{

shipCount = 0;

first = firstdown = lastright = lastdown = NULL;

}

 

 

void addshipFirst(int _x, int _y) //добавление первого корабля

{

ship* newship = new ship(_x, _y);

 

first = newship;

lastright = newship;

lastdown = newship;

shipCount++;

 

}

 

 

void addshipRight(int _x, int _y) //добавление корабля вправо(ячейки)

{

ship* newship = new ship(_x, _y);

 

lastright->nextright = newship;

lastright = newship;

shipCount++;

 

}

void addshipDown(int _x, int _y) //добавление первой ячейки следующего корабля

{

ship* newship = new ship(_x, _y);

 

lastdown->nextdown = newship;

lastdown = newship;

lastright = newship;

shipCount++;

}

 

bool delShip (int _x, int _y) //удаление ячейки

{

ship* prev = NULL,

*current = first,

*lastdown = first,

*prevup = NULL;

while (current) //пока не 0

{

while (current->nextdown) //пока снизу не ноль

{

while(current->nextright) //пока справа не ноль

{

if ((current->x == _x) && (current->y == _y)) //если значения совпали

{

if (current == first) //если первый

{

if(current->nextright) //если справа что-то есть

{

current->nextright->nextdown = current->nextdown;

first = current->nextright;

lastdown = first;

delete current;

shipCount--;

current = first;

return true;

}

else

{

first = current->nextdown;

lastdown = first;

delete current;

shipCount--;

current = first;

return true;

}

 

}

 

else if ((prev == 0) && (prevup!= 0) && (current->nextright!= 0)) //если слева пусто и сверху есть клетка и справа не пусто

{

prevup->nextdown = current->nextright;

current->nextright->nextdown = current->nextdown;

lastdown = current->nextright;

delete current;

shipCount--;

current = lastdown;

return true;

}

 

 

else if (prev) //если предыдущий не равен 0

{

prev->nextright = current->nextright;

delete current;

shipCount--;

current = prev->nextright;

return true;

}

 

}

else //если значения не совпали идём дальше

{

prev = current;

current = current->nextright;

}

}

if ((current->x == _x) && (current->y == _y)) //если справа 0

{

if(prev) //если слева не пусто

{

prev->nextright = 0;

delete current;

shipCount--;

current = prev;

return true;

}

 

else if ((prev == 0) && (prevup!= 0) && (current->nextright == 0) && (current->nextdown!=0)) //если слева пусто и сверху есть клетка и справа пусто и снизу не пусто

{

prevup->nextdown = current->nextdown;

lastdown = current->nextdown;

delete current;

shipCount--;

current = lastdown;

return true;

}

 

}

 

prevup = lastdown;

current = lastdown->nextdown;

lastdown = current;

prev = 0;

 

}

delete current;

shipCount--;

return true;

 

}

return false;

}

}

 

 







Дата добавления: 2015-06-15; просмотров: 419. Нарушение авторских прав; Мы поможем в написании вашей работы!




Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...


Картограммы и картодиаграммы Картограммы и картодиаграммы применяются для изображения географической характеристики изучаемых явлений...


Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...


Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Репродуктивное здоровье, как составляющая часть здоровья человека и общества   Репродуктивное здоровье – это состояние полного физического, умственного и социального благополучия при отсутствии заболеваний репродуктивной системы на всех этапах жизни человека...

Случайной величины Плотностью распределения вероятностей непрерывной случайной величины Х называют функцию f(x) – первую производную от функции распределения F(x): Понятие плотность распределения вероятностей случайной величины Х для дискретной величины неприменима...

Схема рефлекторной дуги условного слюноотделительного рефлекса При неоднократном сочетании действия предупреждающего сигнала и безусловного пищевого раздражителя формируются...

Тема: Изучение приспособленности организмов к среде обитания Цель:выяснить механизм образования приспособлений к среде обитания и их относительный характер, сделать вывод о том, что приспособленность – результат действия естественного отбора...

Тема: Изучение фенотипов местных сортов растений Цель: расширить знания о задачах современной селекции. Оборудование:пакетики семян различных сортов томатов...

Тема: Составление цепи питания Цель: расширить знания о биотических факторах среды. Оборудование:гербарные растения...

Studopedia.info - Студопедия - 2014-2025 год . (0.011 сек.) русская версия | украинская версия