>  기사  >  백엔드 개발  >  PHP에서 배열의 순서를 방해하지만 아래 첨자를 변경하지 않고 유지하는 방법

PHP에서 배열의 순서를 방해하지만 아래 첨자를 변경하지 않고 유지하는 방법

PHPz
PHPz원래의
2023-04-27 15:37:34687검색

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 배열 셔플링을 수행할 수 있습니다. 다음과 같은 장점이 있습니다.

  1. PHP와 함께 제공되는 shuffle() 함수를 사용하면 코드가 간결하고 이해하기 쉽습니다.
  2. 원본 배열을 새 배열에 완전히 복사하면 참조로 인해 발생할 수 있는 문제를 피할 수 있어 코드가 더욱 견고해집니다.
  3. 원본 배열의 데이터 구조와 요소 수를 고려하지 않고 광범위한 응용이 가능하며 모든 유형의 배열에 적합합니다.

그러나 이 방법에도 다음과 같은 단점이 있습니다.

  1. 구현 시 섞인 순서를 저장하기 위해 추가 배열을 사용해야 하며 배열을 제자리에 섞을 수 없습니다.
  2. 대형 어레이의 경우 이 방법은 효율성이 떨어지며 추가 공간을 기반으로 한 탐색 및 채우기 작업이 필요합니다. 대량의 데이터를 스크램블해야 하는 경우에는 보다 효율적인 알고리즘을 사용하는 것이 좋습니다.
  3. 완전한 무작위성을 보장해야 하는 애플리케이션 시나리오(예: 비밀번호 생성)의 경우 shuffle() 함수의 최하위 계층은 무작위 시드 호출에 의존하므로 데이터의 절대 무작위성을 보장할 수 없으며 보다 안전한 무작위 생성이 가능합니다. 알고리즘을 사용해야 합니다.

요약

PHP 프로그래밍에서 배열 요소의 순서를 혼란시키는 것은 일반적인 응용 프로그램 시나리오입니다. shuffle() 함수를 사용하는 것은 PHP에서 배열을 섞는 간단한 방법이지만 이 방법은 원래 배열 첨자의 순서를 변경하여 원래 배열 데이터 구조를 파괴합니다. 원래 배열의 첨자 순서를 파괴하지 않고 PHP 배열 셔플링을 달성하기 위해 셔플링 알고리즘과 유사한 방법을 사용할 수 있습니다. 이 방법에는 특정 제한이 있고 배열을 방해할 수 없지만 광범위한 응용 프로그램이 있으며 코드가 간결하고 이해하기 쉽습니다. PHP 프로그래밍의 실용적인 도구 알고리즘입니다.

위 내용은 PHP에서 배열의 순서를 방해하지만 아래 첨자를 변경하지 않고 유지하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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