>백엔드 개발 >PHP 튜토리얼 >PHP에서 Joseph Ring 문제를 구현하는 방법에 대한 자세한 설명

PHP에서 Joseph Ring 문제를 구현하는 방법에 대한 자세한 설명

jacklove
jacklove원래의
2018-07-06 17:53:172088검색

이 글은 주로 조셉링 문제를 PHP에서 구현하는 방법을 소개하고, 조셉링 문제를 예제 형태로 구현하기 위해 루프와 재귀를 사용하여 PHP의 관련 연산 기법을 분석합니다

이 기사의 예에서는 PHP 메소드에서 Joseph Ring 문제를 구현하는 방법을 알려줍니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.

1. 개요

먼저 인터넷에서 더 일반적인 조셉 링 문제에 대한 설명을 살펴보겠습니다. 조셉 링(Joseph 문제)는 수학적 응용 문제입니다. 주어진 n명의 개인(각각 숫자 1, 2, 3...n으로 표시)이 원탁 주위에 앉아 있습니다. k라는 사람부터 세기 시작하고, m까지 센 사람이 대기열에서 나오고, 다음 사람이 1부터 세기 시작하고, m까지 센 사람이 다시 대기열에서 나옵니다. 테이블 사람들이 다 나왔어요. 보통 이런 유형의 문제를 풀 때는 0부터 n-1까지 번호를 매기는데, 최종 결과 +1이 원래 문제의 해가 됩니다.

2. 구현 코드

1. Loop

function circle($arr,$idx,$k){
  for($i=0;$i<$idx;$i++){
    $tmp = array_shift($arr);
    array_push($arr,$tmp);
  }
  $j = 1;
  while(count($arr) > 0){
    $tmp = array_shift($arr);
    if($j++%$k == 0){
      echo $tmp."\n";
    }else{
      array_push($arr,$tmp);
    }
  }
}
$arr = array(1,2,3,4,5,6,7,8,9,10,11,12);
$idx = 3;
$k = 4;
circle($arr,$idx,$k);

실행 결과:

7 11 3 8 1 6 2 10 9 12 5 4

2.

function circle($arr,$idx,$k){
  $len = count($arr);
  $i = 1;
  if($len == 1){
    echo $arr[0]."\n";
    return ;
  } else {
    while($i++ < $k){
      $idx++;
      $idx = $idx%$len;
    }
    echo $arr[$idx]."\n";
    array_splice($arr,$idx,1);
    circle($arr,$idx,$k);
  }
}
$arr = [1,2,3,4,5,6,7,8,9,10,11,12];
$idx = 3;
$k = 4;
circle($arr,$idx,$k);

실행 결과:

7 11 3 8 1 6 2 10 9 12 5 4

관심을 가질 수 있는 기사:

Passport를 사용하여 Laravel 5.5에서 인증 인증을 구현하는 방법에 대한 설명

간과할 수 있는 PHP의 성능 최적화 도구: 생성기 관련 콘텐츠

Laravel 프레임워크에서 작곡가 자동 로딩의 세부 구현

위 내용은 PHP에서 Joseph Ring 문제를 구현하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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