В каждом множестве поддерживайте счетчик активных электростанций (изначально у домов - 0, у электростанций - 1).
у вас есть какой-то массив ссылок root, элеметы которого указывают сами на себя только в корне множества.
Заведите второй массив, который будет по тем же индексам хранить счетчики для элементов.Я правильно понял, что подразумевается создание массива в классе World, где ключ это айди дома, а значение это кол-во активных станций?
При добавлении провода вы должны слить 2 множества.Имеется ввиду присоединение дома к дому? Надо объединить два массива электростанций подключенных к этим домам?
При запросе на статус дома возьмите счетчик активных станций для его множества и проверьте, что он положителен.Так и сделал. Работает.
householdHasEletricity(householdID) {
const household = this.households.get(householdID);
return household.getActivePowerPlants() > 0;
}
При выключении/включении электростанции измените счетчик соответствующего множества на +1 или на -1.Сделал. Однако теперь отключается только те дома, которые были напрямую подключены к станции, так как в объекте станции доступны только дома с прямым подключением.
killPowerPlant(powerPlantID) {
const powerPlant = this.powerPlants.get(powerPlantID);
const connectedHouseholds = powerPlant.getConnectedHouseholds();
if (powerPlant.getActiveStatus()) {
connectedHouseholds.forEach(householdID => {
const household = this.households.get(householdID);
household.decrementActivePowerPlants();
});
powerPlant.setActiveStatus(false);
}
}
repairPowerPlant(powerPlantID) {
const powerPlant = this.powerPlants.get(powerPlantID);
const connectedHouseholds = powerPlant.getConnectedHouseholds();
if (!powerPlant.getActiveStatus()) {
connectedHouseholds.forEach(householdID => {
const household = this.households.get(householdID);
household.incrementActivePowerPlants();
});
powerPlant.setActiveStatus(true);
}
}
describe("Households + Households + Power Plants", function() {
it("2 Households + 1 Power Plant", () => {
const world = new World();
const household1 = world.createHousehold();
const household2 = world.createHousehold();
const powerPlant = world.createPowerPlant();
world.connectHouseholdToPowerPlant(household1, powerPlant);
world.connectHouseholdToHousehold(household1, household2);
assert.equal(world.householdHasEletricity(household1), true);
assert.equal(world.householdHasEletricity(household2), true);
world.killPowerPlant(powerPlant);
assert.equal(world.householdHasEletricity(household1), false);
assert.equal(world.householdHasEletricity(household2), false); // тут все еще true, так как дом питался от дома
});
});
В чем подввох не пойму? зашел в раздел, проставил в товарах сортировку, в компоненте установил
Это вообще странная мысль. Зачем тебе пользовательское свойство, если ты хочешь какие-то запросы в БД делать, то чем тебя ID раздела не устраивает?
Доп. поле ввода для индекса напротив названия товара - именно напротив? можешь картинку нарисовать?
$hero_images = $pdo->prepare('SELECT path FROM photos WHERE id_hero = :id');
$hero_images->execute(['id' => $hero['id']]);
$hero_images = $hero_images->fetchAll();
$hero['images'] = $hero_images;
$pdo = Database::DataBaseConnect();
$hero = $pdo->prepare('SELECT * FROM heroes WHERE nickname = :nickname');
$hero->execute(['nickname' => $nickname]);
$hero = $hero->fetch();
var_dump($hero);
var_dump($hero['real_name']); // и вот тут "undefined" ?
die();
array(6) { ["id"]=> int(1) ["nickname"]=> string(8) "Superman" ["real_name"]=> string(10) "Clark Kent" ["origin_description"]=> string(158) "he was born Kal-El on the planet Krypton, before being rocketed to Earth as an infant by his scientist father Jor-El, moments before Krypton's destruction..." ["superpowers"]=> string(109) "solar energy absorption and healing factor, solar flare and heat vision, solar invulnerability, flight..." ["catch_phrase"]=> string(68) "“Look, up in the sky, it's a bird, it's a plane, it's Superman!”" }
Notice: Undefined index: real_name in C:\OSPanel\domains\superheroes\application\models\model_hero.php on line 15
NULL
<?php
var_dump($data);
?>
<?php
var_dump($data['real_name']);
?>
array(6) {
["id"]=>
int(1)
["nickname"]=>
string(8) "Superman"
["real_name"]=>
string(10) "Clark Kent"
["origin_description"]=>
string(158) "he was born Kal-El on the planet Krypton, before being rocketed to
Earth as an infant by his scientist father Jor-El, moments before Krypton's destruction..."
["superpowers"]=>
string(109) "solar energy absorption and healing factor, solar flare and heat vision,
solar invulnerability, flight..."
["catch_phrase"]=>
string(68) "“Look, up in the sky, it's a bird, it's a plane, it's Superman!”"
}
Notice: Undefined index: real_name in C:\OSPanel\domains\superheroes\application\views\hero_edit_view.php on line 11
NULL
<?php
class Controller_Hero extends Controller
{
function __construct()
{
$this->model = new Model_Hero();
$this->view = new View();
}
function action_index()
{
}
function action_view($nickname)
{
$data = $this->model->get_hero($nickname);
$this->view->generate('hero_view.php', 'template_view.php', $data);
}
function action_edit ($nickname) {
$data = $this->model->get_hero($nickname);
$this->view->generate('hero_edit_view.php', 'template_view.php', $data);
}
function action_save ($nickname) {
$data = $this->model->save_hero($nickname);
$this->view->generate('hero_edit_view.php', 'template_view.php', $data);
}
}
?>
<?php
class Model_Hero extends Model
{
public function get_hero($nickname)
{
$pdo = Database::DataBaseConnect();
$hero = $pdo->prepare('SELECT * FROM heroes WHERE nickname = :nickname');
$hero->execute(['nickname' => $nickname]);
$hero = $hero->fetch();
$pdo = null;
return $hero;
}
}
<pre>
<?php
var_dump($data['real_name']);
?>
</pre>
<?php
class Database {
static public function DataBaseConnect()
{
$host = 'localhost';
$user = 'root';
$pass = '';
$db = 'superheroes';
$charset = 'utf8';
$dsn = "mysql:host=$host;dbname=$db;charset=$charset";
$opt = array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
PDO::ATTR_EMULATE_PREPARES => false);
$pdo = new PDO($dsn, $user, $pass, $opt);
return $pdo;
}
}
<?php
//если вывожу вот так, то ошибка
var_dump($data['real_name']);
// если так, то выводит
var_dump($data);
?>
array(6) {
["id"]=>
int(1)
["nickname"]=>
string(8) "Superman"
["real_name"]=>
string(10) "Clark Kent"
["origin_description"]=>
string(158) "he was born Kal-El on the planet Krypton, before being rocketed to
Earth as an infant by his scientist father Jor-El, moments before Krypton's destruction..."
["superpowers"]=>
string(109) "solar energy absorption and healing factor, solar flare and heat vision,
solar invulnerability, flight..."
["catch_phrase"]=>
string(68) "“Look, up in the sky, it's a bird, it's a plane, it's Superman!”"
}
- какие задачи вы хотите решить этим скриптом?
- чем ваш seo отдел формировать будет