백엔드 개발 C++ Apple 시스템에서 `rand() % 14`가 6 또는 13만 반환하는 이유는 무엇입니까?

Apple 시스템에서 `rand() % 14`가 6 또는 13만 반환하는 이유는 무엇입니까?

Nov 24, 2024 pm 08:59 PM

Why Does `rand() % 14` Only Return 6 or 13 on Apple Systems?

rand() % 14의 미스터리 6 또는 13만 산출

한 프로그래머가 rand() % 14가 지속적으로 발생하는 특이한 문제에 직면했습니다. C 프로그램에서는 6 또는 13만 반환합니다. 프로그램을 여러 번 실행했음에도 불구하고 이 값은 독점적인 결과입니다.

문제의 코드:

#include <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;

int main(int argc, const char * argv[])
{
    srand(time(NULL));
    cout << rand() % 14;
    return 0;
}
로그인 후 복사

범인: Apple의 MCG 난수 생성기

Wikipedia에 따르면 Apple의 Marsaglia-Crépeau 난수 생성기가 활용하는 승수입니다. (RNG)는 16807입니다. 불행하게도 이 승수는 7로 나눌 수 있습니다. 결과적으로 srand() 이후에 생성된 초기 난수는 모듈로 14의 엔트로피 1비트만 보유하므로 가능한 두 값인 6 또는 13으로 제한됩니다.

간단한 해결책

이 문제를 피하려면 srand() 직후에 생성된 몇 개의 난수. 이렇게 하면 후속 난수의 엔트로피가 증가하여 더 넓은 범위의 값을 허용합니다.

수정된 코드는 다음과 같습니다.

int main(int argc, const char * argv[])
{
    srand(time(NULL));
    
    // Discard the first few random numbers to eliminate the bias
    for (int i = 0; i < 10; ++i)
        rand();
    
    cout << rand() % 14;
    return 0;
}
로그인 후 복사

처음 10개의 난수를 버림으로써, MCG RNG의 결함 있는 승수로 인해 발생하는 편향을 효과적으로 제거할 수 있습니다.

위 내용은 Apple 시스템에서 `rand() % 14`가 6 또는 13만 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까? C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까? Mar 03, 2025 pm 05:52 PM

C 언어 함수에 의해 반환 된 값 유형은 무엇입니까? 반환 값을 결정하는 것은 무엇입니까?

Gulc : C 도서관은 처음부터 구축되었습니다 Gulc : C 도서관은 처음부터 구축되었습니다 Mar 03, 2025 pm 05:46 PM

Gulc : C 도서관은 처음부터 구축되었습니다

C 언어 함수 형식 문자 케이스 변환 단계 C 언어 함수 형식 문자 케이스 변환 단계 Mar 03, 2025 pm 05:53 PM

C 언어 함수 형식 문자 케이스 변환 단계

C 언어 기능의 정의 및 호출 규칙은 무엇이며 C 언어 기능의 정의 및 호출 규칙은 무엇이며 Mar 03, 2025 pm 05:53 PM

C 언어 기능의 정의 및 호출 규칙은 무엇이며

뚜렷한 사용 및 문구 공유 뚜렷한 사용 및 문구 공유 Mar 03, 2025 pm 05:51 PM

뚜렷한 사용 및 문구 공유

메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까? 메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까? Mar 03, 2025 pm 05:51 PM

메모리에 저장된 C 언어 함수의 반환 값은 어디에 있습니까?

C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까? C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까? Mar 12, 2025 pm 04:50 PM

C 표준 템플릿 라이브러리 (STL)는 어떻게 작동합니까?

STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까? STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까? Mar 12, 2025 pm 04:52 PM

STL (정렬, 찾기, 변환 등)의 알고리즘을 효율적으로 사용하려면 어떻게합니까?

See all articles