php 排序,二分查找

$arr = array( 4, 3, 0, 9, 2, 98, 1, -6, 34);
$arr = quickSort($arr);
binnerySearch($arr, 90, 0, count($arr) - 1);

function bubbleSort($arr)
{
    $count = count($arr);
    if ($count <= 1) {
        return $arr;
    }

    for ($i = 0; $i < $count; $i++) {
        for ($j = $count - 1; $j > $i; $j--) {
            if ($arr[$j] > $arr[$j - 1]) {
                $temp = $arr[$j];
                $arr[$j] = $arr[$j - 1];
                $arr[$j - 1] = $temp;
            }
        }
    }
    return $arr;
}

function quickSort($arr)
{
    if (count($arr) <= 1) //如果数组长度小于或者等于1说明数组只有一个值或者为空数组,直接将数组返回。
        {
        return $arr;
    }
    $key = $arr[0]; //将数组的第一个值作为比较标准。
    $leftArr = array(); //比$key小的值会放到这个数组中。
    $rightArr = array(); //比$key大的值会发到这个数组中。
    for ($i = 1; $i < count($arr); $i++) //遍历数组中的值,与$key比较,将小于$key的值放到$leftArr数组中。
        {
        if ($arr[$i] <= $key) {
            $leftArr[] = $arr[$i];
        } else {
            $rightArr[] = $arr[$i];
        }
    }
    $leftArr = quickSort($leftArr); //递归调用自己,知道数组剩下最后一个值并返回。
    $rightArr = quickSort($rightArr); //递归调用自己,知道数组剩下最后一个值并返回。
    return array_merge($leftArr, array($key), $rightArr); //将排序好的数组合并并返回。
}

function binnerySearch($arr, $findVal, $leftIndex, $rightIndex)
{
    if ($leftIndex > $rightIndex) //如果左边的索引范围值大于邮编的说明已经找完了还没找到。
        {
        echo "找不到该值。";
        return false;
    }
    $middleIndex = round(($rightIndex + $leftIndex) / 2);
    if ($findVal == $arr[$middleIndex]) {
        echo "i finde it!";
    } else
        if ($findVal > $arr[$middleIndex]) {
            binnerySearch($arr, $findVal, $middleIndex + 1, $rightIndex);
        } else
            if ($findVal < $arr[$middleIndex]) {
                binnerySearch($arr, $findVal, $leftIndex, $middleIndex - 1);
            } else {
                echo "con't find it!";
            }
}
根据引用的内容,这段引用中包含了一些Vue.js代码和HTML代码,并讨论了换行符和空格在网页中的使用。其中,引用是关于添加和还原换行符的方法,引用是关于在编辑数据时获取详情和使用textarea的示例代码,引用是关于HTML中空格的处理和字符实体的使用。 问题中提到的&nbsp;是HTML中表示空格的字符实体。HTML通常会自动截取多余的空格,不管你加多少空格,都被看做一个空格。为了在网页中增加空格,可以使用&nbsp;表示空格。此外,还有其他常用的字符实体,如<表示小于号,>表示大于号,&表示&符号,"表示双引号,等等。 需要注意的是,引用的内容中有一些HTML实体被转义了,所以在描述字符实体时需要参考编码转义后的字符。 根据给定的引用内容,我无法直接回答问题,因为问题中的信息不完整。请提供更具体的问题或补充说明,我将尽力为您提供帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [js+v-html+正则表达式去除所有& nbsp和html标签(& nbsp 换行 )](https://blog.csdn.net/xm_w_xm/article/details/91992754)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [html&nbsp;&nbsp;特殊字符(转)](https://blog.csdn.net/feiniu5566/article/details/13624619)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值