让我们首先列出我看过的和不要找的东西
我不想列出数组中的所有排列 - Get all permutations of a PHP array?
我不想从数组中按顺序查找所有组合 - https://stackoverflow.com/a/38871855/1260548
上面的两个例子让我走到了现在的位置,但我仍然生成了太多的组合。有了 50 个节点,我最终得到了数十亿甚至数万亿的组合,我认为我可以使用树结构进一步减少它。
我正在寻找的是树中所有可能的有序组合,这些组合可以像这样构造为多维数组
[1]
--[2]
--[4]
[8]
--[3]
--[9]
----[5]
[6]
[7]
我要查找的是所有可能的开放节点(甚至叶/端节点都可以开放)。所以这里的一种可能组合是所有数字,如
这里的节点 1 是 2 和 4 的父节点。8 是 3 和 9 的父节点。9 是 8 的子节点,但是是 5 的父节点。其他可能的组合是。
如果父节点未打开,则无法打开节点。例如,如果不包括 1,则不能包括 2 和 4。如果不包括 9 则不能包括 5,如果不包括 8 则不能包括 3、9 和 5。
以下是我用来生成要测试的示例节点结构的代码。请注意,此结构是有序的并且具有固定的深度,因为我想提出一个适用于任何顺序和任何深度的函数。
$arr = [];
$result = [];
$xtotal = 0;
$ytotal = 0;
$ztotal = 0;
for ($x=0; $x<2; $x++) {
$arr[$xtotal] = array();
$ytotal = $xtotal+1;
for ($y=0; $y<2; $y++) {
$arr[$xtotal][$ytotal] = array();
$ztotal = $ytotal+1;
for ($z=0; $z<2; $z++) {
$arr[$xtotal][$ytotal][$ztotal] = array();
$ztotal++;
}
$ytotal = $ztotal+1;
}
$xtotal = $ytotal+1;
}
for ($c=0; $c<5; $c++) {
$arr[$xtotal] = array();
$xtotal++;
}
所以我想知道如何编写一个函数来列出所有这些可能的组合?
编辑:使用较小的集合我可以列出所有可能的组合。
[1]
--[2]
--[4]
[8]
1
8
1.8
1.2
1.4
1.2.8
1.4.8
1.2.4
1.2.4.8
最佳答案
我想出了一个函数,似乎可以满足您的需求。但是,在存储所有不同的组合时,您很容易开始遇到内存问题。如果您想要 50 个节点,此解决方案可能不适合您,具体取决于内存限制。
我使用了一些不同的节点生成器(虽然我也用你的进行了测试)这让我在创建随机组合时更加灵活:
$arr = [];
$counter = 0;
// you can change the (2,6) to produce different numbers of root nodes
for($i=1;$i<=mt_rand(2,6);$i++){
$curr = $counter++;
$arr[$curr] = [];
// guarantee the first node (0) will have children nodes (easier testing) - random for other nodes
$child = ($curr == 0) ? true : rand(0,1);
if($child){
// you can change the (1,2)
for($j=1;$j<=mt_rand(1,2);$j++){
$curr2 = $counter++;
$arr[$curr][$curr2] = [];
$child2 = rand(0,1);
if($child2){
// you can change the (1,2) here too
for($k=1;$k<=mt_rand(1,2);$k++){
$curr3 = $counter++;
$arr[$curr][$curr2][$curr3] = [];
}
}
}
}
}
现在开始计算:
function treenodes($arr,&$results,$parent=null){
foreach($arr as $k=>$a){
// here we copy all our current results - this gives us one with the current node closed (original), and one with it open (clone)
$clone = [];
foreach($results as $key=>$result){
// if this node is allowed in this result (parent is on) - root nodes are always allowed
if($parent === null || in_array($parent,$result)){
$clone[] = array_merge($result,array($k));
}
}
$results = array_merge($results,$clone);
// if this node has children, run this function on them as well
if(count($a)){
treenodes($a,$results,$k);
}
}
}
// we start with one option of no nodes open
$results = [[]];
treenodes($arr,$results);
// show results - you can order these another way if you'd like before printing
print count($results)."\n";
foreach($results as $result){
print implode(",",$result)."\n";
}
关于php - 如何列出一棵树的所有部分树,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45368891/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
在选择我想要运行操作的频率时,唯一的选项是“每天”、“每小时”和“每10分钟”。谢谢!我想为我的Rails3.1应用程序运行调度程序。 最佳答案 这不是一个优雅的解决方案,但您可以安排它每天运行,并在实际开始工作之前检查日期是否为当月的第一天。 关于ruby-如何每月在Heroku运行一次Scheduler插件?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8692687/
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为