首页 > 后端开发 > php教程 > 从a-f六个字符中取出3-4个字符进行组合该怎么做?

从a-f六个字符中取出3-4个字符进行组合该怎么做?

WBOY
发布: 2016-06-06 20:17:59
原创
1332 人浏览过

<code>$arr=['a','b','c','d','e','f'];</code>
登录后复制
登录后复制

从数组$arr中取出3个或4个字符(两种情况都考虑)组合成新的字符,比如abc,abd,abe,abcd等,同时考虑顺序不同的情况,abc和acb视为不同的情况,将新的字符存入数组,
$newArr[]='abc';
$newArr[]='abd';
$newArr[]='abe';
$newArr[]='abcd';
$newArr[]='acbd';
...

怎样列举所有的情况?

回复内容:

<code>$arr=['a','b','c','d','e','f'];</code>
登录后复制
登录后复制

从数组$arr中取出3个或4个字符(两种情况都考虑)组合成新的字符,比如abc,abd,abe,abcd等,同时考虑顺序不同的情况,abc和acb视为不同的情况,将新的字符存入数组,
$newArr[]='abc';
$newArr[]='abd';
$newArr[]='abe';
$newArr[]='abcd';
$newArr[]='acbd';
...

怎样列举所有的情况?

<code>function dfs($pre, $chars, $arr, $lenArr) {
    if(!empty($pre) && in_array(strlen($pre), $lenArr)){ $arr[] = $pre; }
    if(!empty($chars)) {
        foreach ($chars as $char) {
            $tempChars = array();
            foreach ($chars as $c) {
                if ($c !== $char) { $tempChars[] = $c; }
            }
            $arr = $this->dfs($pre.$char, $tempChars, $arr, $lenArr);
        }
    }
    return $arr;
}

function get_combine() {
    $chars = array('a', 'b', 'c', 'd', 'e', 'f');
    $combineArray = array();
    $combineArray = $this->dfs('', $chars, $combineArray, array(3, 4));
    echo count($combineArray).'<br>';
    var_dump($combineArray);
}

</code>
登录后复制

用递归可以实现

相关标签:
php
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板