我这里有几个函数,我正在努力获得正确的输出。
主要思想是使用名为 buildinginfo 的函数和调用函数 avaliableBuildingBuildings 循环遍历 buildinginfo 的数组和循环遍历要求以找到是否满足要求。
在我的数据库中,我的main_building 级别是 1。
每隔一张 table 都是空的。
调用 avaliableBuildingBuildings 时,我在这一行下得到了输出,其中列出了我可以创建的建筑物。可以看到main_building的要求是3,那么兵营就不要建了。
问:我如何修改我的代码,以便它实际上只提供我可以 build 的建筑物阵列?
当前输出:
array(5) {
["barracks"]=>
array(2) {
["max"]=>
int(1)
["requirements"]=>
array(2) {
["main_building"]=>
int(3)
["rally_point"]=>
int(1)
}
}
["blacksmith"]=>
array(2) {
["max"]=>
int(1)
["requirements"]=>
array(3) {
["main_building"]=>
int(3)
["academy"]=>
int(3)
["barracks"]=>
int(3)
}
}
["embassy"]=>
array(2) {
["max"]=>
int(1)
["requirements"]=>
array(1) {
["main_building"]=>
int(1)
}
}
["marketplace"]=>
array(2) {
["max"]=>
int(1)
["requirements"]=>
array(3) {
["warehouse"]=>
int(1)
["granary"]=>
int(1)
["main_building"]=>
int(3)
}
}
["palace"]=>
array(2) {
["max"]=>
int(1)
["requirements"]=>
array(3) {
["main_building"]=>
int(5)
["embassy"]=>
int(1)
["residence"]=>
int(0)
}
}
}
完整代码:
function isBuilt($villageid,$name) {
$buildinginfo = $this->buildinginfo();
$thisBuilding = $buildinginfo[$name];
$built = $this->CI->db->query("SELECT * from `$name` where `villageid`='$villageid'")->row();
return ($built ? $built : false);
}
function requirementsDone($villageid,$name) {
$buildinginfo = $this->buildinginfo()[$name];
$canbebuilt = true;
if (isset($buildinginfo['requirements'])) {
$requirements = $buildinginfo['requirements'];
foreach ($requirements as $reqname => $level) {
$building = $this->isBuilt($villageid, $reqname);
if ($building) {
echo "needs that $reqname (".$building->level.")is higher than $level to build $name <br><br>";
if ($building->level >= $level) {
echo "<br> $reqname is acually higher ! <br><br>";
} else {
echo " i cant acually build this.. <br><br>";
$canbebuilt = false;
break;
}
} else {
$canbebuilt = false;
break;
}
}
}
if ($canbebuilt) {
echo "result to build $name is true<br>";
} else {
echo "result to build $name is false<br>";
}
return $canbebuilt;
}
function existingBuildings($villageid) {
$buildinginfo = $this->buildinginfo();
$buildings = array();
foreach($buildinginfo as $name => $array) {
$built = $this->isBuilt($villageid,$name);
if ($built) {
$buildings[$name] = $built;
}
}
return $buildings;
}
function avaliableBuildingBuildings($villageid) {
$avaliable = $this->avaliableBuildings($villageid);
$tobuild = array();
foreach($avaliable as $name => $built) {
if (isset($built['requirements'])) {
$req = $built['requirements'];
foreach ($req as $reqname => $level) {
$canbuild = $this->requirementsDone($villageid, $reqname);
if ($canbuild) {
echo "verify to build $reqname is true <br><br>";
$tobuild[$name] = $avaliable[$name];
} else {
echo "verify to build $reqname is false <br><br>";
break;
}
}
} else {
}
}
return $tobuild;
}
function avaliableBuildings($villageid) {
$buildinginfo = $this->buildinginfo();
foreach($this->existingBuildings($villageid) as $name => $built) {
if (array_key_exists($name,$buildinginfo)) {
unset($buildinginfo[$name]);
echo "removing $name <br>";
}
}
return $buildinginfo;
}
function buildinginfo() {
$info = array(
'academy' => array('max' => 1),
'barracks' => array('max' => 1,
'requirements' => array(
'main_building' => 3,
'rally_point' => 1,
)
),
'main_building' => array('max' => 1,
'requirements' => array(
'main_building' => 1,
)
),
'greatbarracks' => array('max' => 1),
'greatstable' => array('max' => 1),
'heromansion' => array('max' => 1),
'rally_point' => array('max' => 1),
'stable' => array('max' => 1,'requirements' => array(
'blacksmith' => 3,
'academy' => 5,
)
),
'blacksmith' => array('max' => 1,'requirements' => array(
'main_building' => 3,
'academy' => 3,
'barracks' => 3,
)
),
'forge' => array('max' => 1),
'tournament_square' => array('max' => 1),
'trapper' => array('max' => 1),
'cranny' => array('max' => 1),
'embassy' => array('max' => 1,
'requirements' => array(
'main_building' => 1
)
),
'marketplace' => array('max' => 1,'requirements' => array(
'warehouse' => 1,
'granary' => 1,
'main_building' => 3
)
),
'palace' => array('max' => 1,
'requirements' => array(
'main_building' => 5,
'embassy' => 1,
'residence' => 0
)
),
'residence' => array('max' => 1),
'town_hall' => array('max' => 1),
'trade_office' => array('max' => 1),
'treasury' => array('max' => 1),
'granary' => array('max' => 99, 'new' => 20),
'warehouse' => array('max' => 99, 'new' => 20)
);
return $info;
最佳答案
看起来您的要求检查循环增加了一倍。这导致检查是否可以 build 任何所需的建筑物(并且它总是可以,因为没有嵌套的要求)。只需摆脱内部循环,它应该没问题。
function avaliableBuildingBuildings($villageid) {
$avaliable = $this->avaliableBuildings($villageid);
$tobuild = array();
foreach ($avaliable as $name => $built) {
if (isset($built['requirements'])) {
if ($this->requirementsDone($villageid, $name)) {
echo "verify to build $name is true <br><br>";
$tobuild[$name] = $avaliable[$name];
} else {
echo "verify to build $name is false <br><br>";
}
} else {
}
}
return $tobuild;
}
附言。那些“echo ”没有帮助,是吗?:)想想 TDD - 这个过程解决的问题不仅仅是逻辑错误(它会迫使你引入假数据层,例如 -> 解耦代码)
关于完成要求的 PHP 返回数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37718850/
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我的代码目前看起来像这样numbers=[1,2,3,4,5]defpop_threepop=[]3.times{pop有没有办法在一行中完成pop_three方法中的内容?我基本上想做类似numbers.slice(0,3)的事情,但要删除切片中的数组项。嗯...嗯,我想我刚刚意识到我可以试试slice! 最佳答案 是numbers.pop(3)或者numbers.shift(3)如果你想要另一边。 关于ruby-多次弹出/移动ruby数组,我们在StackOverflow上找到一
我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我正在使用puppet为ruby程序提供一组常量。我需要提供一组主机名,我的程序将对其进行迭代。在我之前使用的bash脚本中,我只是将它作为一个puppet变量hosts=>"host1,host2"我将其提供给bash脚本作为HOSTS=显然这对ruby不太适用——我需要它的格式hosts=["host1","host2"]自从phosts和putsmy_array.inspect提供输出["host1","host2"]我希望使用其中之一。不幸的是,我终其一生都无法弄清楚如何让它发挥作用。我尝试了以下各项:我发现某处他们指出我需要在函数调用前放置“function_”……这
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
我有一个这样的哈希数组:[{:foo=>2,:date=>Sat,01Sep2014},{:foo2=>2,:date=>Sat,02Sep2014},{:foo3=>3,:date=>Sat,01Sep2014},{:foo4=>4,:date=>Sat,03Sep2014},{:foo5=>5,:date=>Sat,02Sep2014}]如果:date相同,我想合并哈希值。我对上面数组的期望是:[{:foo=>2,:foo3=>3,:date=>Sat,01Sep2014},{:foo2=>2,:foo5=>5:date=>Sat,02Sep2014},{:foo4=>4,:dat
我正在尝试在Ruby中制作一个cli应用程序,它接受一个给定的数组,然后将其显示为一个列表,我可以使用箭头键浏览它。我觉得我已经在Ruby中看到一个库已经这样做了,但我记不起它的名字了。我正在尝试对soundcloud2000中的代码进行逆向工程做类似的事情,但他的代码与SoundcloudAPI的使用紧密耦合。我知道cursesgem,我正在考虑更抽象的东西。广告有没有人见过可以做到这一点的库或一些概念证明的Ruby代码可以做到这一点? 最佳答案 我不知道这是否是您正在寻找的,但也许您可以使用我的想法。由于我没有关于您要完成的工作
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我使用Ember作为我的前端和GrapeAPI来为我的API提供服务。前端发送类似:{"service"=>{"name"=>"Name","duration"=>"30","user"=>nil,"organization"=>"org","category"=>nil,"description"=>"description","disabled"=>true,"color"=>nil,"availabilities"=>[{"day"=>"Saturday","enabled"=>false,"timeSlots"=>[{"startAt"=>"09:00AM","endAt"=>