중간제곱법은 난수를 생성하는 가장 간단한 방법 중 하나입니다. 이 방법은 동일한 번호를 반복적으로 생성하기 시작하거나 시퀀스의 이전 번호로 순환하고 무한 루프합니다. n자리 난수 생성기의 경우 기간은 n보다 길 수 없습니다. 중간 n자리가 모두 0이면 Generator는 영원히 0을 출력하지만 이러한 0의 실행은 감지하기 쉽지만 이 방법을 실용적으로 사용하기에는 너무 자주 발생합니다.
Input − Enter the digit for random number:4 Output − The random numbers are: 6383, 14846, 8067, 51524, .........
알고리즘
Begin middleSquareNumber(number, digit) Declare an array and assign next_number=0. Square the number and assign it to a variable sqn. Divide the digit by 2 and assign it to a variable t. Divide sqn by a[t] and store it to sqn. For i=0 to digit, do next_number =next _number (sqn mod (a[t])) * (a[i]); sqn = sqn / 10; Done Return the next number End.
예시 코드
#include <iostream> using namespace std; int a[] = { 1, 10, 100, 1000, 10000, 100000, 1000000, 10000000, 100000000 }; int middleSquareNumber(int number, int digit) { int sqn = number * number, next_number = 0; int t = (digit / 2); sqn = sqn / a[t]; for (int i = 0; i < digit; i++) { next_number += (sqn % (a[t])) * (a[i]); sqn = sqn / 10; } return next_number; } int main(int argc, char **argv) { cout << "Enter the digit random numbers you want: "; int n; cin >> n; int start = 1; int end = 1; start = a[n - 1]; end = a[n]; int number = ((rand()) % (end - start)) + start; cout << "The random numbers are:\n" << number << ", "; for (int i = 1; i < n; i++) { number = middleSquareNumber(number, n); cout << number << ", "; } cout << "........."; }
출력
Enter the digit random numbers you want: 4 The random numbers are: 6383, 14846, 8067, 51524, .........