조셉 링 문제를 해결하기 위한 기사 1개(PHP 버전)
이 기사에서는 PHP 버전의 Joseph Ring 문제(원숭이가 왕을 선택함)를 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.
요셉 반지 문제(원숭이가 왕을 선택) PHP 버전
요세푸스 문제는 원숭이가 왕을 선택하는 문제로 설명되기도 하는데 제목은 다음과 같습니다. (요셉의 문제의 근원은 마지막에 포스팅하겠습니다)
원형으로 늘어선 원숭이 무리는 1, 2,...,n에 따라 번호가 매겨져 있습니다.
그럼 첫 번째부터 세고, m번째까지 세고, 원 밖으로 쫓아내고, 뒤에서부터 세기 시작하고, m번째까지 세고, 쫓아내고..., 그리고 이런 식으로 계속, 거기까지 이제 원숭이 한 마리만 남았는데, 그 원숭이를 왕이라고 부릅니다.
이 과정을 시뮬레이션하고 m, n을 입력하고 마지막 왕의 수를 출력하려면 프로그래밍이 필요합니다.
프로그램을 사용하여 이 과정을 시뮬레이션합니다.
function monkeyKing($n, $m) { $arr = range(1, $n); //构造一个数组 $i = 1; //从第一个开始循环 while (count($arr) > 1) { //如果总数大于1 if ($i % $m != 0) { $arr[] = $arr[$i - 1]; //不被踢出则压入数组尾部 } unset($arr[$i - 1]); //压入数组然后删除 $i++; //继续循环 } return $arr[$i - 1]; //直至最后剩下一个为大王 } print_r(monkeyKing(5, 3)); //第4只为大王
다음은 시뮬레이션 과정입니다. 제거되지 않은 원숭이에 대해 배열의 꼬리가 계속 추가됩니다.
$n = 5 $m = 3 $arr = [1, 2, 3, 4, 5] $i $arr ---+------------------------ 1 x 2 3 4 5 1 2 x x 3 4 5 1 2 >3 x x x 4 5 1 2 4 x x x x 5 1 2 4 5 x x x x x 1 2 4 5 >6 x x x x x x 2 4 5 7 x x x x x x x 4 5 2 8 x x x x x x x x 5 2 4 >9 x x x x x x x x x 2 4 10 x x x x x x x x x x 4 2 11 x x x x x x x x x x x 2 4 >12 x x x x x x x x x x x x 4
Joseph의 질문 출처:
이 질문은 플라비오(Flavio)에 기초한 것입니다. 1세기 유대인 역사가인 요세푸스(Josephus)의 이름을 따서 명명되었습니다. 그는 일기에 자신과 동료 40명이 동굴에서 로마군에 둘러싸여 있었다고 적었습니다. 자살할지, 체포할지 논의하다가 결국 자살을 하기로 했고, 제비를 뽑아 누가 누구를 죽일지 결정했다. 요세푸스와 다른 한 사람이 마지막 두 사람이 남았습니다. 요세푸스는 그 사람에게 그들이 로마 군대에 항복하고 다시는 자살하지 않을 것이라고 설득했습니다. 요세푸스는 자신의 생존을 행운이나 섭리 덕분이라고 생각했지만 어느 쪽인지는 몰랐습니다.
추천 학습: "PHP 비디오 튜토리얼"
위 내용은 조셉 링 문제를 해결하기 위한 기사 1개(PHP 버전)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

CakePHP에 로그인하는 것은 매우 쉬운 작업입니다. 한 가지 기능만 사용하면 됩니다. cronjob과 같은 백그라운드 프로세스에 대해 오류, 예외, 사용자 활동, 사용자가 취한 조치를 기록할 수 있습니다. CakePHP에 데이터를 기록하는 것은 쉽습니다. log() 함수는 다음과 같습니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.
