輸入一個三位數,輸出最大值,例如輸入725輸出752…并且可以輸入正負數。排除0;
其實大緻思路就是負數的時候倒序排列,正數的時候升序排列。
方法很多,有使用冒泡排序,我也試了一下 ,不過好像沒有辦法把運算符變為動态的,代碼就有點重複了。也有使用取模運算的,我這裡利用php的數組排序asort以及arsort方法。上代碼:
public function strMax(){
//使用者輸入的值
$arr = '527';
// 字元串長度
$len = strlen($arr);
$array = [];
for ($i=0; $i < $len; $i++) {
//字元串也可以通過數組形式取到單個字元
array_push($array, $arr[$i]);
}
//根據數組的值降序
arsort($array);
$result = implode('', $array);
print_r(intval($result));die;
}
這裡可以使用strpos判斷是否存在負号,存在負号則升序排列,不存在則降序排序。
網上的答案也貼上吧,冒泡排序的方法:
public function maoPao()
{
$arr = '543';
$len = 3;
for($i = 0;$i < $len -1;$i ++){
for($j = 0;$j < $len - $i -1;$j ++){
if ($arr[$j] < $arr[$j+1]) {
$temp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1] = $temp;
}
}
}
print_r(intval($arr));die;
}
以及