.
:
a -> 2
b -> 3
c -> 5
.
.
, - .
; , .
[a, b, b, c] :
[2, 3, 3, 5]
:
[2, 3^2, 5]
, :
[2^1, 3^2, 5^1]
:
[2,3,5]
[1,2,1]
, , [p] ^ [e] , ; , .. , .
, 2^1*5^1 == 3^2*3^2; , .
[a, b, b, a, b, b]:
[2^1, 3^2, 2^1, 3^2]
,
[2, 3, 2, 3]
[1, 2, 1, 2]
, 2^1 * 3^2 == 3^2 * 2^1 ( , , , )
, .
[b, b, b, b, b]:
[3^5]
,
[3]
[5]
: 1 , .
[b, b, b, b, a]:
[3^4, 2^1]
,
[3, 2]
[4, 1]
, 3^4 == 2^1, , .
[a, b, a, b, a, b]:
[2^1, 3^1, 2^1, 3^1, 2^1, 3^1]
,
[2, 3, 2, 3, 2, 3]
[1, 1, 1, 1, 1, 1]
, 2^1 * 3^1 == 3^1 * 2^1 == 2^1 * 3^1
, :
.
, ,
, , p e, n, :
var start = p[0]^e[0] * p[n-1]^e[n-1]
var reducible = true;
for (int i = 0; i < n/2, ++i) :
if ( (p[i]^e[i] * p[n-i]^e[n-i]) != start ) :
reducible = false;
break;
. . .
, , n, , .
: - , , . , , , .