php实现霍兰德代码计算

霍兰德.png
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 $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实现霍兰德代码计算)