diff options
| author | Adrien Hopkins <adrien.p.hopkins@gmail.com> | 2023-08-07 15:49:44 -0500 |
|---|---|---|
| committer | Adrien Hopkins <adrien.p.hopkins@gmail.com> | 2023-08-18 14:26:13 -0500 |
| commit | b4bdd6146962d8dde391f09b2cdda9553cb44bde (patch) | |
| tree | 861e0803d0a16c8fb0b65e86c2d98cef632f0cea /factors/factorize.go | |
| parent | 8c6419bde0cb6893cf7e789c8fceaea5638c95ff (diff) | |
Add list of factors to output
Diffstat (limited to 'factors/factorize.go')
| -rw-r--r-- | factors/factorize.go | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/factors/factorize.go b/factors/factorize.go new file mode 100644 index 0000000..2f7368a --- /dev/null +++ b/factors/factorize.go @@ -0,0 +1,27 @@ +package factors + +// Factors returns a number's factors as a slice. +// The slice is not guaranteed to be in sorted order. +func Factors(n uint) []uint { + if n == 0 { + panic("Cannot get factors of 0!") + } + + primeFactorization := PrimeFactorize(n) + + factors := []uint{1} + for p, e := range primeFactorization.exponents { + next_factors := make([]uint, 0, len(factors) * int(e)) + for _, factor := range factors { + for i := uint(0); i <= e; i++ { + multiplier := uint(1) + for j := uint(0); j < i; j++ { + multiplier *= p + } + next_factors = append(next_factors, factor * multiplier) + } + } + factors = next_factors + } + return factors +} |
