일일 프로그램 PHP 지식 PHP 클래식 흥미로운 알고리즘

PHP 클래식 흥미로운 알고리즘

Jul 16, 2019 pm 03:12 PM
php 연산

많은 사람들이 C 언어를 배울 때 흥미로운 알고리즘을 작성했습니다. 실제로 이러한 알고리즘은 PHP에서도 구현할 수 있으며 일부 알고리즘의 코드는 C 언어의 코드보다 훨씬 간단합니다.

더 많은 PHP 팁을 보려면 우리를 클릭하세요

1. 원숭이 원을 그리며 배열하고 1, 2,...,n에 따라 순차적으로 번호를 매깁니다. 그런 다음 첫 번째부터 세기 시작하고, m 번째까지 세고, 원 밖으로 쫓아내고, 뒤에서 세기 시작하고, m 번째까지 세고, 쫓아내고... 끝까지 이런 식으로 계속합니다. 이제 원숭이는 한 마리밖에 남지 않았는데, 그 원숭이를 왕이라고 부릅니다. 이 과정을 시뮬레이션하여 m, n을 입력하고 마지막 왕의 수를 출력하는 프로그래밍이 필요합니다.

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);


2. 4세가 되면 새끼를 낳을 수 있는 소가 있습니다. 소는 매년 한 마리씩 새끼를 낳습니다. 같은 소에게 15살에 중성화수술을 하면 더 이상 번식력이 없어 20살에 죽습니다. n년 안에 소는 몇 마리나 될까요?

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;
}
}

3. 양희삼각

<?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();
?>

4. #

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;
}

5. 빠른 정렬

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);
}

6. 이진 검색 알고리즘(반 검색 알고리즘)

#. 🎜🎜#

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;
}

7.PHP singular Algorithm

<?php
function test(){
 $a=1;
 $b=&$a;
 echo (++$a)+(++$a);
}
test();
PHP7 이하 버전은 6을 반환하고, PHP7 버전은 5를 반환합니다. 이상합니다. 저는 개인적으로 기본 알고리즘이 좋지 않다고 생각합니다. PHP7


8 이하 버전에서는 버그인 것 같습니다. 문자열을 수집하고 순서대로 정렬합니다(영어)

function set($str){
    //转化为数组
    $arr = str_split($str);
    //去除重复
    $arr = array_flip(array_flip($arr));
    //排序
    sort($arr);
    //返回字符串
    return implode(&#39;&#39;, $arr);
}
9. 파일 아래의 모든 파일과 하위 폴더

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;			//输出文件名
				}
			}
		} 
	}
}
# 🎜🎜#10. 표준 URL

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

11에서 파일 확장자를 추출하세요. 한 번에 1~2단계만 수행할 수 있습니다. 질문: 이 사람이 단계를 완료할 수 있는 방법은 몇 가지입니까? 예: 총 3단계가 있습니다. 1단계를 먼저 수행한 다음 2단계를 수행하거나, 2단계를 먼저 수행한 다음 1단계를 수행하거나, 1단계를 3번 수행하여 총 3가지 방법을 사용할 수 있습니다. #🎜🎜 #

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

12 여러 프로세스가 동시에 동일한 파일을 성공적으로 작성할 수 있도록 PHP 코드를 작성해 주세요.

<?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);
?>
#🎜🎜 #

13. 무제한 분류# 🎜🎜#

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;
    }

14 지난달 1일과 마지막 날을 가져옵니다.

//获取上个月第一天
    date(&#39;Y-m-01&#39;,strtotime(&#39;-1 month&#39;));
 
    //获取上个月最后一天
    date(&#39;Y-m-t&#39;,strtotime(&#39;-1 month&#39;));
15. 임의의 1을 입력하세요. 숫자는 해당 데이터 간격을 쿼리할 수 있습니다

//把区间换成数组写法,用二分法查找区间
	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;
	        }   
	    }
 
	    return &#39;在区间&#39;.$a[$high].&#39;到&#39;.$a[$lower];  
	}
 
	$array  = [&#39;1&#39;,&#39;50&#39;,&#39;100&#39;,&#39;150&#39;,&#39;200&#39;,&#39;250&#39;,&#39;300&#39;];
	$a = &#39;120&#39;;
	echo binsearch($a,$array);

위 내용은 PHP 클래식 흥미로운 알고리즘의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제

램프 스택 너머 : 현대 기업 아키텍처에서 PHP의 역할 램프 스택 너머 : 현대 기업 아키텍처에서 PHP의 역할 Jul 27, 2025 am 04:31 AM

PhpisstillRelevantinmodernenterpriseenvironments.1. Modernphp (7.xand8.x)는 엄격한 성능, 엄격한 성능, jitcompilation 및 modernsyntax, mateitsuilableforlarge-scalepplications

PHP의 객체 관계 매핑 (ORM) 성능 튜닝 PHP의 객체 관계 매핑 (ORM) 성능 튜닝 Jul 29, 2025 am 05:00 AM

N 1 쿼리 문제를 피하고 관련 데이터를 미리로드하여 데이터베이스 쿼리 수를 줄입니다. 2. 메모리와 대역폭을 저장하기 위해 완전한 엔티티를로드하지 않도록 필요한 필드 만 선택하십시오. 3. 교리의 2 차 캐시 또는 Redis 캐시 고주파 쿼리 결과와 같은 캐시 전략을 합리적으로 사용하십시오. 4. 엔티티 수명주기를 최적화하고 정기적으로 Clear ()을 호출하여 메모리를 자유롭게하여 메모리 오버플로를 방지합니다. 5. 데이터베이스 색인이 존재하는지 확인하고 비효율적 인 쿼리를 피하기 위해 생성 된 SQL 문을 분석하십시오. 6. 변경 사항이 필요하지 않은 시나리오에서 자동 변경 추적을 비활성화하고 배열 또는 경량 모드를 사용하여 성능을 향상시킵니다. ORM을 올바르게 사용하려면 개발 효율을 유지하면서 응용 프로그램 성능을 보장하기 위해 SQL 모니터링, 캐싱, 배치 처리 및 적절한 최적화를 결합해야합니다.

PHP 및 RabbitMQ로 탄력성 마이크로 서비스 구축 PHP 및 RabbitMQ로 탄력성 마이크로 서비스 구축 Jul 27, 2025 am 04:32 AM

유연한 PHP 마이크로 서비스를 구축하려면 RabbitMQ를 사용하여 비동기 통신을 달성하고 1. 캐스케이드 고장을 피하기 위해 메시지 대기열을 통해 서비스를 분리해야합니다. 2. 신뢰성을 보장하기 위해 지속적인 대기열, 지속적인 메시지, 확인 및 수동 ACK를 구성합니다. 3. 지수 백 오프 재 시도, TTL 및 데드 레터 큐 보안 처리 실패를 사용하십시오. 4. Supervisord와 같은 도구를 사용하여 소비자 프로세스를 보호하고 서비스 건강을 보장하기 위해 하트 비트 메커니즘을 가능하게합니다. 그리고 궁극적으로 시스템이 실패로 지속적으로 작동하는 능력을 실현합니다.

파이썬 실행 쉘 명령 예제 파이썬 실행 쉘 명령 예제 Jul 26, 2025 am 07:50 AM

Subprocess.run ()을 사용하여 쉘 명령을 안전하게 실행하고 출력을 캡처하십시오. 주입 위험을 피하기 위해 목록에 매개 변수를 전달하는 것이 좋습니다. 2. 쉘 특성이 필요한 경우, shell = true를 설정할 수 있지만 명령 주입을 조심하십시오. 3. 하위 프로세스를 사용하여 실시간 출력 처리를 실현하십시오. 4. SET Check = 명령이 실패 할 때 예외를 던지기 위해 true; 5. 간단한 시나리오에서 체인을 직접 호출하여 출력을 얻을 수 있습니다. OS.System () 또는 더 이상 사용되지 않은 모듈을 사용하지 않으려면 일상 생활에서 Subprocess.run ()에 우선 순위를 부여해야합니다. 위의 방법은 파이썬에서 쉘 명령을 실행하는 핵심 사용을 무시합니다.

vscode settings.json 위치 vscode settings.json 위치 Aug 01, 2025 am 06:12 AM

settings.json 파일은 사용자 수준 또는 작업 공간 수준 경로에 있으며 VSCODE 설정을 사용자 정의하는 데 사용됩니다. 1. 사용자 수준 경로 : Windows는 C : \ Users \\ AppData \ Roaming \ Code \ User \ Settings.json, MacOS IS /users//library/applicationsupport/code/user/settings.json, linux는 /home//.config/code/user/settings.json; 2. Workspace 수준 경로 : .vscode/settings project root 디렉토리

PHP 용 생산 준비 도커 환경 생성 PHP 용 생산 준비 도커 환경 생성 Jul 27, 2025 am 04:32 AM

올바른 PHP 기본 이미지를 사용하고 안전하고 성능 최적화 된 Docker 환경을 구성하는 것이 생산 준비를위한 핵심입니다. 1. PHP : 8.3-fpm-alpine을 기본 이미지로 선택하여 공격 표면을 줄이고 성능을 향상시킵니다. 2. 사용자 정의 php.ini를 통해 위험한 기능을 비활성화하고, 오류 표시를 끄고, Opcache 및 JIT를 활성화하여 보안 및 성능을 향상시킵니다. 3. Nginx를 리버스 프록시로 사용하여 민감한 파일에 대한 액세스를 제한하고 PHP 요청을 PHP-FPM으로 올바르게 전달합니다. 4. 다단계 최적화 이미지를 사용하여 개발 종속성을 제거하고 컨테이너를 실행하도록 뿌리가 아닌 사용자를 설정하십시오. 5. CRON과 같은 여러 프로세스를 관리하기위한 선택적 감독 조종; 6. 배포 전에 민감한 정보 누출이 없는지 확인하십시오

Serverless Revolution : BREF를 사용하여 확장 가능한 PHP 응용 프로그램을 배포합니다 Serverless Revolution : BREF를 사용하여 확장 가능한 PHP 응용 프로그램을 배포합니다 Jul 28, 2025 am 04:39 AM

BREF를 통해 PHP 개발자는 서버를 관리하지 않고 확장 가능하고 비용 효율적인 응용 프로그램을 구축 할 수 있습니다. 1. Bref는 최적화 된 PHP 런타임 레이어를 제공하고 PHP8.3 및 기타 버전을 지원하며 Laravel 및 Symfony와 같은 프레임 워크와 완벽하게 통합하여 PHP를 Awslambda에 가져옵니다. 2. 배포 단계에는 다음이 포함됩니다 : Composer를 사용하여 BREF 설치, HTTP 엔드 포인트 및 장인 명령과 같은 기능 및 이벤트를 정의하기 위해 Serverless.yml 구성; 3. ServerlessDeploy 명령을 실행하여 배포를 완료하고 APIGINGWARE를 자동으로 구성하고 액세스 URL을 생성합니다. 4. Lambda 제한을 위해 Bref는 솔루션을 제공합니다.

Readonly 속성으로 PHP에 불변의 물체를 구축합니다 Readonly 속성으로 PHP에 불변의 물체를 구축합니다 Jul 30, 2025 am 05:40 AM

readOnlyPropertiesInphp8.2CanonlyBeassignedOnedOneDonceIntheConstructorAratDeclarationandCannotBemodififificificificifified

See all articles