您的位置:首页 > 职场人生

PHP百度面试题:版本号排序

2016-04-27 13:21 816 查看
http://blog.csdn.net/aoyoo111/article/details/19909995

思路是用explode分割为数组,取出每一项比较

<?php

$versionArr=array(  

    "99.101.202.1.0",  

    "111.101.202.1.1",  

    "112.101.202.1.1",  

    "111.98.202.1.1",  

    "111.103.201.0.1"  

    );  

     

//比较函数  

function comparefun($va,$vb){  

    $a = array_shift($va);  

    $b = array_shift($vb);  

    if($a>$b){  

        return 1;  

    }elseif($a<$b){  

        return 0;  

    }else{  

        return comparefun($va,$vb);  

    }  

}  

     

array_walk($versionArr, function(&$value){  

    $value = explode('.', $value);  

});  

     

for($i=0;$i<count($versionArr)-1;$i++ ){        

    for($j=0;$j<count($versionArr)-1-$i;$j++){  

        if(comparefun($versionArr[$j],$versionArr[$j+1])){  

            $tmp = $versionArr[$j];  

            $versionArr[$j] = $versionArr[$j+1];  

            $versionArr[$j+1] = $tmp;  

        }  

    }  

}  

     

array_walk($versionArr, function(&$value){  

    $value = implode('.', $value);  

});  

     echo '<pre>';
print_r($versionArr); 

ps:权限的整理可以用到递归,也可以整理一个各级权限数值字符串拼接类似上边的字符串,按照ascii码排序(要求权限数目不大),这样可不用递归
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: