PHP 프로그래밍에서는 난수 세트를 정렬해야 하거나 데이터 세트를 무작위로 샘플링해야 하는 등 배열 요소의 순서를 방해해야 하는 시나리오에 자주 직면합니다. 일반적으로 PHP에 포함된 shuffle() 함수를 사용하여 배열 요소를 섞을 수 있지만 이 함수는 요소의 키 값을 변경하여 원래 배열 순서의 첨자가 변경되어 원본이 파괴됩니다. 데이터 구조. 이 기사에서는 배열 첨자의 순서를 변경하지 않고 PHP 배열 셔플링을 구현하는 방법을 소개합니다.
메서드 구현
배열 순서 첨자를 변경하지 않고 PHP 배열 셔플링을 구현하려면 셔플링 알고리즘과 유사한 방법을 사용할 수 있습니다. 즉, 모든 배열 요소를 새 배열에 복사하고 무작위로 새 배열을 생성하는 것입니다. 정렬 순서. 그런 다음 원래 배열을 반복하고 해당 요소를 새 순서에 따라 하나씩 새 배열에 채웁니다. 이런 방식으로 원래 배열의 아래 첨자 순서는 변경되지 않았지만 배열 요소의 정렬 순서는 무작위로 지정되었습니다. PHP 코드는 다음과 같습니다.
function shuffleArray($arr) {
// 배열 복사
$newArr = $arr;
// 무작위 정렬
shuffle($newArr);
// 원본 배열 탐색
foreach ($arr as $key => $value) {
// 将元素按照新顺序填充到新数组中 $arr[$key] = $newArr[$key];
}
// 새 배열 반환
return $arr;
}
이 함수는 입력 배열 $arr를 받아 섞인 순서로 새 배열을 반환합니다. . 구현에서는 참조로 인해 발생할 수 있는 잠재적인 문제를 피하기 위해 먼저 $newArr = $arr을 사용하여 원본 배열을 새 배열에 완전히 복사합니다. 다음으로, PHP 자체 shuffle() 함수를 사용하여 새 배열을 무작위로 정렬합니다. 마지막으로 원래 배열을 반복하고 해당 요소를 새 순서에 따라 하나씩 새 배열에 채우고 새 배열을 반환합니다.
이 방법의 장점과 단점
위 방법을 사용하면 원래 배열 첨자의 순서를 변경하지 않고도 PHP 배열 셔플링을 수행할 수 있습니다. 다음과 같은 장점이 있습니다.
그러나 이 방법에도 다음과 같은 단점이 있습니다.
요약
PHP 프로그래밍에서 배열 요소의 순서를 혼란시키는 것은 일반적인 응용 프로그램 시나리오입니다. shuffle() 함수를 사용하는 것은 PHP에서 배열을 섞는 간단한 방법이지만 이 방법은 원래 배열 첨자의 순서를 변경하여 원래 배열 데이터 구조를 파괴합니다. 원래 배열의 첨자 순서를 파괴하지 않고 PHP 배열 셔플링을 달성하기 위해 셔플링 알고리즘과 유사한 방법을 사용할 수 있습니다. 이 방법에는 특정 제한이 있고 배열을 방해할 수 없지만 광범위한 응용 프로그램이 있으며 코드가 간결하고 이해하기 쉽습니다. PHP 프로그래밍의 실용적인 도구 알고리즘입니다.
위 내용은 PHP에서 배열의 순서를 방해하지만 아래 첨자를 변경하지 않고 유지하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!