<?php
//二三四五部分的总和数组
$sum=array('R'=>2,'I'=>9,'A'=>5,'S'=>5,'E'=>5,'C'=>5);
//第二部分的统计结果
$partTwo=array('R'=>2,'I'=>4,'A'=>3,'S'=>5,'E'=>5,'C'=>1);
//第三部分的统计结果
$partThree=array('R'=>2,'I'=>2,'A'=>3,'S'=>5,'E'=>4,'C'=>1);
//第四部分的统计结果
$partFour=array('R'=>2,'I'=>1,'A'=>3,'S'=>4,'E'=>5,'C'=>1);
/**
*比较这种数组的大小
* $arr = [1,2,3]
*规则是如果$arr[0] > $arr1[0] 则$arr > $arr1 ,如果$arr[0] = $arr1[0] 则比较$arr[1]和 $arr1[1]
*/
function compare($arr1,$arr2){
foreach ($arr1 as $item){
$arr1 = $item;
}
foreach ($arr2 as $item){
$arr2 = $item;
}
for($i=0;$i<count($arr1);$i++){
if($arr1[$i] > $arr2[$i]){
return 1; //第一个数组大于第二个数组
}elseif($arr1[$i] < $arr2[$i]){
return 2; //第二个数组大于第一个数组
}
}
return 0;//两个数组相等
}
$arrKey = [];
//对总和排序
arsort($sum);
$arrArr = [];
//将排序总和,各个分段数据,组合成一个数组,最前面的数字优先级最高
foreach ($sum as $k => $v){
if(!is_array($arrArr[$k])){
$arrArr[$k] = [];
}
$arrArr[$k][] = $v;
$i++;
}
//第四部分优先
foreach ($partFour as $k => $v){
$arrArr[$k][] = $v;
$i++;
}
//第二部分其次
foreach ($partTwo as $k => $v){
$arrArr[$k][] = $v;
$i++;
}
//第三部分最后
foreach ($partThree as $k => $v){
$arrArr[$k][] = $v;
$i++;
}
//再封转一层数组,便于后续冒泡排序
$sortArr = [];
foreach ($arrArr as $k => $v){
$sortArr[] = array($k => $v);
}
//复杂数组冒泡排序,排序后的索引即为正常的顺序
for ($i=0;$i<6;$i++){
for($j=0;$j<6-1-$i;$j++){
$code = compare($sortArr[$j],$sortArr[$j+1]);
if($code == 2){
$temp = $sortArr[$j];
$sortArr[$j] = $sortArr[$j+1];
$sortArr[$j+1] = $temp;
}
}
}
$str = '';
for($i=0;$i<3;$i++){
foreach ($sortArr[$i] as $k=>$v){
$str .= $k;
}
}
echo $str;
?>
php实现霍兰德代码计算
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...