php 数组 任意 排列 组合
和部门同时讨论了一上午了,没有讨论出结果来,基本需求如下:假设:
$a = array('a');
$b = array('b');
$c = array('c');
$d = array('d');
通过一个函数获取以下结果:
array(
a+b+c+d,
ab+c+d,
ac+b+d,
ad+b+c,
bc+ad,
bc+a+d,
bd+ac,
bd+a+c
cd+ab,
cd+a+b,
abc+a,
acd+b,
abd+c,
bcd+a,
...
)
即获取所有数组的组合方式,任意组合数组排序不一定按照顺序,但是要求组合必须出现全部元素。
有高人给个好的算法或者思路么?
回复讨论(解决方案)
用现成的函数实现,未作优化
$a = array('a', 'b', 'c', 'd');$res = array();foreach(arrangement($a) as $v) { $res = array_merge($res, foo(explode(' ', trim($v))));}print_r($res);//排列 arrangementfunction arrangement($arr = array(), $res = '') { if(! is_array($arr) ) $arr = str_split($arr); if(empty($arr)) $array[] = $res; else foreach($arr AS $k => $v) { unset($arr[$k]); foreach( Arrangement($arr, $res . " $v") AS $t) $array[] = $t; $arr[$k] = $v; } return $array;}function foo($ar) { $res = array(); if(count($ar) > 2) { $t = array_shift($ar); foreach(foo($ar) as $v) { $res[] = "$t$v"; $res[] = "$t+$v"; } }else { $res[] = "$ar[0]$ar[1]"; $res[] = "$ar[0]+$ar[1]"; } return $res;}
Array( [0] => abcd [1] => a+bcd [2] => ab+cd [3] => a+b+cd [4] => abc+d [5] => a+bc+d [6] => ab+c+d [7] => a+b+c+d [8] => abdc [9] => a+bdc [10] => ab+dc [11] => a+b+dc [12] => abd+c [13] => a+bd+c [14] => ab+d+c [15] => a+b+d+c [16] => acdb [17] => a+cdb [18] => ac+db [19] => a+c+db [20] => acd+b [21] => a+cd+b [22] => ac+d+b [23] => a+c+d+b [24] => acbd [25] => a+cbd [26] => ac+bd [27] => a+c+bd [28] => acb+d [29] => a+cb+d [30] => ac+b+d [31] => a+c+b+d [32] => adbc [33] => a+dbc [34] => ad+bc [35] => a+d+bc [36] => adb+c [37] => a+db+c [38] => ad+b+c [39] => a+d+b+c [40] => adcb [41] => a+dcb [42] => ad+cb [43] => a+d+cb [44] => adc+b [45] => a+dc+b [46] => ad+c+b [47] => a+d+c+b [48] => bcda [49] => b+cda [50] => bc+da [51] => b+c+da [52] => bcd+a [53] => b+cd+a [54] => bc+d+a [55] => b+c+d+a [56] => bcad [57] => b+cad [58] => bc+ad [59] => b+c+ad [60] => bca+d [61] => b+ca+d [62] => bc+a+d [63] => b+c+a+d [64] => bdac [65] => b+dac [66] => bd+ac [67] => b+d+ac [68] => bda+c [69] => b+da+c [70] => bd+a+c [71] => b+d+a+c [72] => bdca [73] => b+dca [74] => bd+ca [75] => b+d+ca [76] => bdc+a [77] => b+dc+a [78] => bd+c+a [79] => b+d+c+a [80] => bacd [81] => b+acd [82] => ba+cd [83] => b+a+cd [84] => bac+d [85] => b+ac+d [86] => ba+c+d [87] => b+a+c+d [88] => badc [89] => b+adc [90] => ba+dc [91] => b+a+dc [92] => bad+c [93] => b+ad+c [94] => ba+d+c [95] => b+a+d+c [96] => cdab [97] => c+dab [98] => cd+ab [99] => c+d+ab [100] => cda+b [101] => c+da+b [102] => cd+a+b [103] => c+d+a+b [104] => cdba [105] => c+dba [106] => cd+ba [107] => c+d+ba [108] => cdb+a [109] => c+db+a [110] => cd+b+a [111] => c+d+b+a [112] => cabd [113] => c+abd [114] => ca+bd [115] => c+a+bd [116] => cab+d [117] => c+ab+d [118] => ca+b+d [119] => c+a+b+d [120] => cadb [121] => c+adb [122] => ca+db [123] => c+a+db [124] => cad+b [125] => c+ad+b [126] => ca+d+b [127] => c+a+d+b [128] => cbda [129] => c+bda [130] => cb+da [131] => c+b+da [132] => cbd+a [133] => c+bd+a [134] => cb+d+a [135] => c+b+d+a [136] => cbad [137] => c+bad [138] => cb+ad [139] => c+b+ad [140] => cba+d [141] => c+ba+d [142] => cb+a+d [143] => c+b+a+d [144] => dabc [145] => d+abc [146] => da+bc [147] => d+a+bc [148] => dab+c [149] => d+ab+c [150] => da+b+c [151] => d+a+b+c [152] => dacb [153] => d+acb [154] => da+cb [155] => d+a+cb [156] => dac+b [157] => d+ac+b [158] => da+c+b [159] => d+a+c+b [160] => dbca [161] => d+bca [162] => db+ca [163] => d+b+ca [164] => dbc+a [165] => d+bc+a [166] => db+c+a [167] => d+b+c+a [168] => dbac [169] => d+bac [170] => db+ac [171] => d+b+ac [172] => dba+c [173] => d+ba+c [174] => db+a+c [175] => d+b+a+c [176] => dcab [177] => d+cab [178] => dc+ab [179] => d+c+ab [180] => dca+b [181] => d+ca+b [182] => dc+a+b [183] => d+c+a+b [184] => dcba [185] => d+cba [186] => dc+ba [187] => d+c+ba [188] => dcb+a [189] => d+cb+a [190] => dc+b+a [191] => d+c+b+a)
多谢版主,函数我有话下,去重就OK啦。
去重后再次贴出,多谢先,稍后确认。
有重复的吗?显然没有
print_r(array_unique($res));
和
print_r($res);
的结果一样!
var_dump(count($res) == count(array_unique($res)));
bool(true)
抱歉版主,我没有解释清楚,A+B+C+D 和 B+A+C+D, D+C+A+B等算一种。

PHP类型提示提升代码质量和可读性。1)标量类型提示:自PHP7.0起,允许在函数参数中指定基本数据类型,如int、float等。2)返回类型提示:确保函数返回值类型的一致性。3)联合类型提示:自PHP8.0起,允许在函数参数或返回值中指定多个类型。4)可空类型提示:允许包含null值,处理可能返回空值的函数。

PHP中使用clone关键字创建对象副本,并通过\_\_clone魔法方法定制克隆行为。1.使用clone关键字进行浅拷贝,克隆对象的属性但不克隆对象属性内的对象。2.通过\_\_clone方法可以深拷贝嵌套对象,避免浅拷贝问题。3.注意避免克隆中的循环引用和性能问题,优化克隆操作以提高效率。

PHP适用于Web开发和内容管理系统,Python适合数据科学、机器学习和自动化脚本。1.PHP在构建快速、可扩展的网站和应用程序方面表现出色,常用于WordPress等CMS。2.Python在数据科学和机器学习领域表现卓越,拥有丰富的库如NumPy和TensorFlow。

HTTP缓存头的关键玩家包括Cache-Control、ETag和Last-Modified。1.Cache-Control用于控制缓存策略,示例:Cache-Control:max-age=3600,public。2.ETag通过唯一标识符验证资源变化,示例:ETag:"686897696a7c876b7e"。3.Last-Modified指示资源最后修改时间,示例:Last-Modified:Wed,21Oct201507:28:00GMT。

在PHP中,应使用password_hash和password_verify函数实现安全的密码哈希处理,不应使用MD5或SHA1。1)password_hash生成包含盐值的哈希,增强安全性。2)password_verify验证密码,通过比较哈希值确保安全。3)MD5和SHA1易受攻击且缺乏盐值,不适合现代密码安全。

PHP是一种服务器端脚本语言,用于动态网页开发和服务器端应用程序。1.PHP是一种解释型语言,无需编译,适合快速开发。2.PHP代码嵌入HTML中,易于网页开发。3.PHP处理服务器端逻辑,生成HTML输出,支持用户交互和数据处理。4.PHP可与数据库交互,处理表单提交,执行服务器端任务。

PHP在过去几十年中塑造了网络,并将继续在Web开发中扮演重要角色。1)PHP起源于1994年,因其易用性和与MySQL的无缝集成成为开发者首选。2)其核心功能包括生成动态内容和与数据库的集成,使得网站能够实时更新和个性化展示。3)PHP的广泛应用和生态系统推动了其长期影响,但也面临版本更新和安全性挑战。4)近年来的性能改进,如PHP7的发布,使其能与现代语言竞争。5)未来,PHP需应对容器化、微服务等新挑战,但其灵活性和活跃社区使其具备适应能力。

PHP的核心优势包括易于学习、强大的web开发支持、丰富的库和框架、高性能和可扩展性、跨平台兼容性以及成本效益高。1)易于学习和使用,适合初学者;2)与web服务器集成好,支持多种数据库;3)拥有如Laravel等强大框架;4)通过优化可实现高性能;5)支持多种操作系统;6)开源,降低开发成本。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

Atom编辑器mac版下载
最流行的的开源编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器