Heim > Backend-Entwicklung > PHP-Tutorial > PHP interessante klassische Algorithmen

PHP interessante klassische Algorithmen

Guanhui
Freigeben: 2023-04-08 18:02:02
nach vorne
3002 Leute haben es durchsucht

PHP interessante klassische Algorithmen

Viele Leute haben beim Erlernen der C-Sprache einige interessante Algorithmen geschrieben. Tatsächlich können diese Algorithmen auch in PHP implementiert werden, und sogar die Codes einiger Algorithmen sind länger als die in der C-Sprache . prägnant.

1. Eine Gruppe Affen stellt sich im Kreis auf und wird nach 1, 2,..., n nummeriert. Dann beginnen Sie mit dem Zählen vom ersten, zählen Sie bis zum m-ten, werfen Sie es aus dem Kreis, beginnen Sie von hinten zu zählen, zählen Sie bis zum m-ten, werfen Sie es raus ... und fahren Sie auf diese Weise bis zum Ende fort Es gibt nur noch einen Affen, den man „König“ nennt. Um diesen Prozess zu simulieren, ist eine Programmierung erforderlich. Geben Sie m und n ein und geben Sie die Nummer des letzten Königs aus.

function king($n, $m){
    $monkeys = range(1, $n);         //创建1到n数组
    $i=0;
    while (count($monkeys)>1) {   //循环条件为猴子数量大于1
        if(($i+1)%$m==0) {   //$i为数组下标;$i+1为猴子标号
            unset($monkeys[$i]);    //余数等于0表示正好第m个,删除,用unset删除保持下标关系
        } else {
            array_push($monkeys,$monkeys[$i]);     //如果余数不等于0,则把数组下标为$i的放最后,形成一个圆形结构
            unset($monkeys[$i]);
        }
            $i++;//$i 循环+1,不断把猴子删除,或 push到数组 
    }
    return current($monkeys);   //猴子数量等于1时输出猴子标号,得出猴王
}
echo king(6,3);
Nach dem Login kopieren

2. Es gibt eine Kuh, die im Alter von 4 Jahren fruchtbar wird. Jedes Jahr wird eine Kuh geboren. Alle Nachkommen sind die gleiche Kuh. Sie wird im Alter von 15 Jahren sterilisiert Sie stirbt im Alter von 20 Jahren. Wie viele werden es nach n Jahren sein?

function niu($y){
    static $num= 1;                 //定义静态变量;初始化牛的数量为1
    for ($i=1; $i <=$y ; $i++) {     
        if($i>=4 && $i<15){         //每年递增来算,4岁开始+1,15岁不能生育
        $num++;
            niu($y-$i);             //递归方法计算小牛$num,小牛生长年数为$y-$i
        }else if($i==20){           
        $num--;                          //20岁死亡减一
        }
    return $num;
}
}
Nach dem Login kopieren

3. Yang-Hui-Dreieck

<?php
/* 默认输出十行,用T(值)的形式可改变输出行数 */
class T{
  private $num;
  public function __construct($var=10) {
    if ($var<3) die("值太小啦!");
    $this->num=$var;
  }
  public function display(){
    $n=$this->num;
    $arr=array();
  //$arr=array_fill(0,$n+1,array_fill(0,$n+1,0));
    $arr[1]=array_fill(0,3,0);
    $arr[1][1]=1;
    echo str_pad(" ",$n*12," ");
    printf("%3d",$arr[1][1]);
    echo "<br/>";
    for($i=2;$i<=$n;$i++){
      $arr[$i]=array_fill(0,($i+2),0);
      for($j=1;$j<=$i;$j++){
        if($j==1)
          echo str_pad(" ",($n+1-$i)*12," ");
        printf("%3d",$arr[$i][$j]=$arr[$i-1][$j-1]+$arr[$i-1][$j]);
        echo "  ";
      }
      echo"<br/>";
    }
  }
}
$yh=new T(&#39;3&#39;); //$yh=new T(数量);
$yh->display();
?>
Nach dem Login kopieren

4. Blasensortierung

function maopao($arr){
    $len = count($arr); 
    for($k=0;$k<=$len;$k++)
    {
        for($j=$len-1;$j>$k;$j--){
          if($arr[$j]<$arr[$j-1]){
            $temp = $arr[$j];
            $arr[$j] = $arr[$j-1];
            $arr[$j-1] = $temp;
          }
        }
    }
    return $arr;
}
Nach dem Login kopieren

6. Binärer Suchalgorithmus )

function quickSort($arr) {
    //先判断是否需要继续进行
    $length = count($arr);
    if($length <= 1) {
        return $arr;
    }
    //选择第一个元素作为基准
    $base_num = $arr[0];
    //遍历除了标尺外的所有元素,按照大小关系放入两个数组内
    //初始化两个数组
    $left_array = array();  //小于基准的
    $right_array = array();  //大于基准的
    for($i=1; $i<$length; $i++) {
        if($base_num > $arr[$i]) {
            //放入左边数组
            $left_array[] = $arr[$i];
        } else {
            //放入右边
            $right_array[] = $arr[$i];
        }
    }
    //再分别对左边和右边的数组进行相同的排序处理方式递归调用这个函数
    $left_array = quickSort($left_array);
    $right_array = quickSort($right_array);
    //合并
  
    return array_merge($left_array, array($base_num), $right_array);
}
Nach dem Login kopieren

7. PHP seltsamer Algorithmus

function binsearch($x,$a){
    $c=count($a);
    $lower=0;
    $high=$c-1;
    while($lower<=$high){
        $middle=intval(($lower+$high)/2);
        if($a[$middle]>$x){
            $high=$middle-1;
        } elseif($a[$middle]<$x){
            $lower=$middle+1;
        } else{
            return $middle;
        }
    }
    return false;
}
Nach dem Login kopieren

Die Version unter PHP7 gibt 6 zurück und die PHP7-Version gibt 5 zurück. Ich persönlich finde den zugrunde liegenden Algorithmus schlecht Es handelt sich um die Version unterhalb von PHP7. Zeichensatz: Geben Sie eine Zeichenfolge ein, suchen Sie den in der Zeichenfolge enthaltenen Zeichensatz und sortieren Sie ihn der Reihe nach.

<?php
function test(){
 $a=1;
 $b=&$a;
 echo (++$a)+(++$a);
}
test();
Nach dem Login kopieren

9 unter Unterordnern

function set($str){
    //转化为数组
    $arr = str_split($str);
    //去除重复
    $arr = array_flip(array_flip($arr));
    //排序
    sort($arr);
    //返回字符串
    return implode(&#39;&#39;, $arr);
}
Nach dem Login kopieren

10. Extrahieren Sie die Dateierweiterung aus einer Standard-URL

function AllFile($dir){
    if($dh = opendir($dir)){
        while (($file = readdir($dh)) !== false){
            if($file !=&#39;..&#39; && $file !=&#39;.&#39;){
                if(is_dir($dir.&#39;/&#39;.$file)){
                    AllFile($dir.&#39;/&#39;.$file);    //如果判断还是文件,则递归
                }else{  
                    echo $file;         //输出文件名
                }
            }
        } 
    }
}
Nach dem Login kopieren

11. Jemand möchte n Ebenen hinaufsteigen, kann aber nur 1 oder 2 Stufen auf einmal nehmen. Fragen Sie: Auf wie viele Arten kann diese Person die Schritte ausführen? Zum Beispiel: Es gibt insgesamt 3 Schritte. Sie können zuerst Schritt 1 und dann Schritt 2 machen, oder zuerst Schritt 2 und dann Schritt 1, oder Schritt 1 Level 3 Mal, insgesamt 3 Möglichkeiten

function getExt($url)
 {
 $arr = parse_url($url);
 $file = basename($arr[&#39;path&#39;]);// basename函数返回路径中的文件名部分
 $ext = explode(&#39;.&#39;, $file);
 return $ext[count($ext)-1];
 }
Nach dem Login kopieren

12 . Bitte schreiben Sie einen PHP-Absatzcode, um sicherzustellen, dass mehrere Prozesse gleichzeitig erfolgreich in dieselbe Datei schreiben.

function jieti($num){   //实际上是斐波那契数列
 return $num<2?1:jieti($num-1)+jieti($num-2);
 }
Nach dem Login kopieren

Unbegrenzte Klassifizierung

<?php
 $fp = fopen("lock.txt","w+");
 if (flock($fp,LOCK_EX)) {
 //获得写锁,写数据
 fwrite($fp, "write something");
  
 // 解除锁定
 flock($fp, LOCK_UN);
 } else {
 echo "file is locking...";
 }
 fclose($fp);
?>
Nach dem Login kopieren

14 vorheriger Monat // Den vorherigen Monat abrufen Tag 1

function tree($arr,$pid=0,$level=0){
 static $list = array();
 foreach ($arr as $v) {
 //如果是顶级分类,则将其存到$list中,并以此节点为根节点,遍历其子节点
 if ($v[&#39;pid&#39;] == $pid) {
 $v[&#39;level&#39;] = $level;
 $list[] = $v;
 tree($arr,$v[&#39;id&#39;],$level+1);
 }
 }
 return $list;
 }
Nach dem Login kopieren

Empfohlenes Tutorial: „PHP-Tutorial

Das obige ist der detaillierte Inhalt vonPHP interessante klassische Algorithmen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
php
Quelle:juejin.im
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage