侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

php用学算法吗

php  /  管理员 发布于 7年前   144

php用学算法吗?

php需要学习基本的排序算法,因为算法是程序的核心,一个程序的好坏,关键就是这个程序算法的优劣,当然掌握基础算法主要也是为了锻炼逻辑思维。

php的几种算法如下

<?  //--------------------  // 基本数据结构算法 //--------------------  //二分查找(数组里查找某个元素)  function bin_sch($array,  $low, $high, $k){       if ( $low <= $high){           $mid =  intval(($low+$high)/2 );           if ($array[$mid] ==  $k){   return $mid;           }elseif ( $k < $array[$mid]){   return  bin_sch($array, $low,  $mid-1, $k);           }else{   return  bin_sch($array, $mid+ 1, $high, $k);           }       }       return -1;   }   //顺序查找(数组里查找某个元素)  function  seq_sch($array, $n,  $k){       $array[$n] =  $k;       for($i=0;  $i<$n; $i++){           if( $array[$i]==$k){   break;           }       }       if ($i<$n){           return  $i;       }else{           return -1;       }   }   //线性表的删除(数组中实现)  function delete_array_element($array , $i)  {          $len =  count($array);           for ($j= $i; $j<$len; $j ++){      $array[$j] = $array [$j+1];          }          array_pop ($array);          return $array ;  }  //冒泡排序(数组排序)  function bubble_sort( $array)  {          $count = count( $array);          if ($count <= 0 ) return false;          for($i=0 ; $i<$count; $i ++){      for($j=$count-1 ; $j>$i; $j--){  if ($array[$j] < $array [$j-1]){           $tmp = $array[$j];           $array[$j] = $array[ $j-1];          $array [$j-1] = $tmp;  }      }          }          return $array;  }  //快速排序(数组排序)  function quick_sort($array ) {          if (count($array) <= 1) return  $array;          $key = $array [0];          $left_arr  = array();          $right_arr = array();          for ($i= 1; $i<count($array ); $i++){      if ($array[ $i] <= $key)  $left_arr [] = $array[$i];      else   $right_arr[] = $array[$i ];          }          $left_arr = quick_sort($left_arr );          $right_arr = quick_sort( $right_arr);          return array_merge($left_arr , array($key), $right_arr);  }  //------------------------  // PHP内置字符串函数实现  //------------------------  //字符串长度  function strlen ($str)  {          if ($str == '' ) return 0;          $count =  0;          while (1){      if ( $str[$count] != NULL){   $count++;  continue;      }else{  break;      }          }          return $count;  }  //截取子串  function substr($str, $start,  $length=NULL)  {          if ($str== '' || $start>strlen($str )) return;          if (($length!=NULL) && ( $start>0) && ($length> strlen($str)-$start)) return;          if (( $length!=NULL) && ($start< 0) && ($length>strlen($str )+$start)) return;          if ($length ==  NULL) $length = (strlen($str ) - $start);        if ($start <  0){      for ($i=(strlen( $str)+$start); $i<(strlen ($str)+$start+$length ); $i++) {  $substr .=  $str[$i];      }          }          if ($length  > 0){      for ($i= $start; $i<($start+$length ); $i++) {  $substr  .= $str[$i];      }          }          if ( $length < 0){      for ($i =$start; $i<(strlen( $str)+$length); $i++) {  $substr .= $str[$i ];      }          }          return $substr;  }  //字符串翻转  function strrev($str)  {          if ($str == '') return 0 ;          for ($i=(strlen($str)- 1); $i>=0; $i --){      $rev_str .= $str[$i ];          }          return $rev_str;  }  //字符串比较  function strcmp($s1,  $s2)  {          if (strlen($s1) <  strlen($s2)) return -1 ;          if (strlen($s1) > strlen( $s2)) return 1;          for ($i =0; $i<strlen($s1 ); $i++){      if ($s1[ $i] == $s2[$i]){  continue;      }else{  return false;      }          }          return  0;  }  //查找字符串  function  strstr($str, $substr)  {           $m = strlen($str);          $n = strlen($substr );          if ($m < $n) return false ;          for ($i=0; $i <=($m-$n+1); $i ++){      $sub = substr( $str, $i, $n);      if ( strcmp($sub, $substr) ==  0)  return $i;          }          return false ;  }  //字符串替换  function str_replace($substr , $newsubstr, $str)  {           $m = strlen($str);          $n = strlen($substr );          $x = strlen($newsubstr );          if (strchr($str, $substr ) == false) return false;          for ( $i=0; $i<=($m- $n+1); $i++){       $i = strchr($str,  $substr);      $str = str_delete ($str, $i, $n);      $str = str_insert($str,  $i, $newstr);          }          return $str ;  }  //--------------------  // 自实现字符串处理函数 //--------------------  //插入一段字符串  function str_insert($str, $i , $substr)  {          for($j=0 ; $j<$i; $j ++){      $startstr .= $str[$j ];          }          for ($j=$i; $j <strlen($str); $j ++){      $laststr .= $str[$j ];          }          $str = ($startstr . $substr  . $laststr);          return $str ;  }  //删除一段字符串  function str_delete($str , $i, $j)  {          for ( $c=0; $c<$i;  $c++){      $startstr .= $str [$c];          }          for ($c=( $i+$j); $c<strlen ($str); $c++){      $laststr  .= $str[$c];          }           $str = ($startstr . $laststr );          return $str;  }  //复制字符串  function strcpy($s1, $s2 )  {          if (strlen($s1)==NULL || !isset( $s2)) return;          for ($i=0 ; $i<strlen($s1);  $i++){      $s2[] = $s1 [$i];          }          return $s2;  }  //连接字符串  function strcat($s1 , $s2)  {          if (!isset($s1) || !isset( $s2)) return;          $newstr = $s1 ;          for($i=0; $i <count($s); $i ++){      $newstr .= $st[$i ];          }          return $newsstr;  }  //简单编码函数(与php_decode函数对应)  function php_encode($str)  {          if ( $str=='' && strlen( $str)>128) return false;          for( $i=0; $i<strlen ($str); $i++){       $c = ord($str[$i ]);      if ($c>31 && $c <107) $c += 20 ;      if ($c>106 && $c <127) $c -= 75 ;      $word = chr($c );      $s .= $word;          }           return $s;   }  //简单解码函数(与php_encode函数对应)  function php_decode($str)  {          if ( $str=='' && strlen($str )>128) return false;          for( $i=0; $i<strlen ($str); $i++){      $c  = ord($word);      if ( $c>106 && $c<127 ) $c = $c-20;      if ($c>31 && $c< 107) $c = $c+75 ;      $word = chr( $c);      $s .= $word ;          }           return $s;   }  //简单加密函数(与php_decrypt函数对应)  function php_encrypt($str)  {           $encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890';           $decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359';          if ( strlen($str) == 0) return  false;          for ($i=0;  $i<strlen($str); $i ++){      for ($j=0; $j <strlen($encrypt_key); $j ++){  if ($str[$i] == $encrypt_key [$j]){          $enstr .=  $decrypt_key[$j];          break;  }      }          }          return $enstr;  }  //简单解密函数(与php_encrypt函数对应)  function php_decrypt($str)  {           $encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890';           $decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359';          if ( strlen($str) == 0) return  false;          for ($i=0;  $i<strlen($str); $i ++){      for ($j=0; $j <strlen($decrypt_key); $j ++){  if ($str[$i] == $decrypt_key [$j]){          $enstr .=  $encrypt_key[$j];          break;  }      }          }          return $enstr;  }  ?>

更多PHP相关知识,请访问!

以上就是php用学算法吗的详细内容,更多请关注其它相关文章!


  • 上一条:
    php工作在公司主要做什么
    下一条:
    php有必要学面向对象吗
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客