백엔드 개발 PHP 튜토리얼 约瑟夫环问题的PHP实现 使用PHP数组内部指针操作函数_PHP

约瑟夫环问题的PHP实现 使用PHP数组内部指针操作函数_PHP

Jun 01, 2016 pm 12:17 PM
PHP 배열 내부 포인터

来看看这个问题的详细描述:
view sourceprint?一群猴子排成一圈,按 1,2,...,n 依次编号。然后从第 1 只开始数,数到第 m 只,把它踢出圈,从它后面再开始数, 再数到第 m 只,在把它踢出去...,如此不停的进行下去, 直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入 m、n, 输出最后那个大王的编号。
刚开始构思的时候想使用 PHP 数组来实现(当然最后还是使用的数组),然后模拟一个数组的内部指针,结果发现想模拟一个“数组指针”不是那么的容易,因为涉及到很多“指针”的操作,最后猛然想到,PHP 的数组本身就是有内部指针的,为什么还要去“造车轮子”呢?!于是乎~看代码:
复制代码 代码如下:
function getKingMonkey($n, $m)
{
$a = array();//声明内部数组
for($i = 1; $i {
$a[$i] = $i;//这一步是对号入座
}
reset($a);//为了严谨,我们来一个 reset() 函数,其实也可以省去
while(count($a) > 1)//主循环开始,这里使用的判别条件是数组元素的个数等于 1 的时候停止循环
{
for($counter = 1; $counter {
if(next($a)){//如果存在 next 元素
if($counter == $m)
{
unset($a[array_search(prev($a), $a)]);//当数到 m 时,使用 unset() 删除数组元素
}
}
else//如果不存在 next 元素
{
reset($a);//则数组的第一个元素充当 next 元素
if($counter == $m)
{
unset($a[array_search(end($a), $a)]);//当数到 m 时,使用 unset() 删除数组元素,注意这里是 end()
reset($a);//记得让数组内部指针“归位”
}
}
}
}
return current($a);
}

测试一下下:
echo "猴子大王的编号为:" . getKingMonkey(100, 17);
输出为:
view sourceprint?猴子大王的编号为:53
The End~

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

뜨거운 기사 태그

메모장++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 15, 2023 pm 12:24 PM

PHP 배열을 사용하여 차트와 통계 그래프를 생성하고 표시하는 방법

PHP 배열을 사용하여 동적 슬라이드쇼 및 이미지 디스플레이를 생성하는 방법 PHP 배열을 사용하여 동적 슬라이드쇼 및 이미지 디스플레이를 생성하는 방법 Jul 15, 2023 pm 01:17 PM

PHP 배열을 사용하여 동적 슬라이드쇼 및 이미지 디스플레이를 생성하는 방법

PHP 배열을 사용하여 사용자 로그인 및 권한 관리 기능을 구현하는 방법 PHP 배열을 사용하여 사용자 로그인 및 권한 관리 기능을 구현하는 방법 Jul 15, 2023 pm 08:55 PM

PHP 배열을 사용하여 사용자 로그인 및 권한 관리 기능을 구현하는 방법

PHP 배열 키-값 쌍이란 무엇입니까? PHP 배열 키-값 쌍이란 무엇입니까? Aug 03, 2023 pm 02:20 PM

PHP 배열 키-값 쌍이란 무엇입니까?

PHP에 배열이 몇 개 있는지 확인하는 방법 PHP에 배열이 몇 개 있는지 확인하는 방법 Aug 04, 2023 pm 05:40 PM

PHP에 배열이 몇 개 있는지 확인하는 방법

PHP에서 배열 결합의 효과적인 구현 PHP에서 배열 결합의 효과적인 구현 Apr 30, 2024 pm 01:03 PM

PHP에서 배열 결합의 효과적인 구현

PHP 배열의 성능 최적화 기술 탐색 PHP 배열의 성능 최적화 기술 탐색 Mar 13, 2024 pm 03:03 PM

PHP 배열의 성능 최적화 기술 탐색

배열이 비어 있는지 확인하는 PHP의 함수는 무엇입니까? 배열이 비어 있는지 확인하는 PHP의 함수는 무엇입니까? Aug 03, 2023 pm 05:15 PM

배열이 비어 있는지 확인하는 PHP의 함수는 무엇입니까?

See all articles