C#에서 소수 생성 강화
귀하의 C# 코드는 지정된 범위 내의 소수를 식별하는 것을 목표로 하지만 현재 결함이 있어 출력되지 않습니다. 문제는 소수를 결정하는 데 사용되는 알고리즘에 있습니다.
코드 이해:
prime_num
메서드는 주어진 num
까지의 소수를 찾으려고 시도합니다. isPrime
을 true
으로 초기화하고 0부터 num
까지의 숫자를 반복합니다. 각 숫자 i
에 대해 2부터 num
까지의 숫자로 나누어지는지 확인합니다. i
을 자신 이외의 숫자로 나눌 수 있으면 isPrime
은 false
이 됩니다. 모든 확인 후 isPrime
가 true
로 남아 있는 경우에만 i
가 프라임으로 간주되어 인쇄됩니다.
오류 식별:
주요 오류는 외부 루프의 증분(for (int i = 0; i <= num; i )
)입니다. 여기에는 소수가 아닌 0이 포함되어 불필요한 검사를 수행합니다. 내부 루프도 중복 계산을 수행합니다.
더 효율적인 솔루션:
최적의 소수 생성을 위해서는 에라토스테네스의 체를 고려하세요. 이 알고리즘은 2부터 시작하여 각 소수의 배수를 제거하여 성능을 크게 향상시킵니다. 이를 통해 필요한 확인 횟수가 크게 줄어듭니다.
요컨대 원본 코드의 비효율성은 잘못된 루프 반복과 중복 검사에서 비롯됩니다. 에라토스테네스의 체 또는 시험 분할 체와 같은 보다 효율적인 알고리즘을 사용하면 올바른 소수를 훨씬 더 빨리 얻을 수 있습니다.
위 내용은 효율적인 소수 생성을 위해 C# 코드를 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!