123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- #!/usr/bin/perl
- # Author: Daniel "Trizen" Șuteu
- # License: GPLv3
- # Date: 09 July 2015
- # Website: https://github.com/trizen
- # Split a semiprime into a group of equations.
- use 5.010;
- use strict;
- use integer;
- use warnings;
- sub semiprime_equationization {
- my ($semiprime, $xlen, $ylen) = @_;
- $xlen -= 1;
- $ylen -= 1;
- my @map;
- my $mem = '0';
- foreach my $j (0 .. $ylen) {
- foreach my $i (0 .. $xlen) {
- my $n = '(' . join(' + ', "(x[$i] * y[$j])", grep { $_ ne '0' } $mem) . ')';
- if ($i == $xlen) {
- push @{$map[$j]}, "($n % 10)", "int($n / 10)";
- $mem = '0';
- }
- else {
- push @{$map[$j]}, "($n % 10)";
- $mem = "int($n / 10)";
- }
- }
- my $n = $ylen - $j;
- if ($n > 0) {
- push @{$map[$j]}, ((0) x $n);
- }
- my $m = $ylen - $n;
- if ($m > 0) {
- unshift @{$map[$j]}, ((0) x $m);
- }
- }
- my @number = reverse split //, $semiprime;
- my @result;
- my @mrange = (0 .. $#map);
- foreach my $i (0 .. $#number) {
- my $n = '(' . join(' + ', grep { $_ ne '0' } (map { $map[$_][$i] } @mrange), $mem) . ')';
- if ($i == 0 or $i == $#number) {
- push @result, "$number[$i] = $n";
- $mem = '0';
- }
- else {
- push @result, "$number[$i] = ($n % 10)";
- $mem = "int($n / 10)";
- }
- }
- return @result;
- }
- # 71 * 43
- #say for semiprime_equationization('3053', 2, 2);
- # 251 * 197
- say for semiprime_equationization('49447', 3, 3);
- # 37975227936943673922808872755445627854565536638199 * 40094690950920881030683735292761468389214899724061
- #say for semiprime_equationization('1522605027922533360535618378132637429718068114961380688657908494580122963258952897654000350692006139', 50, 50);
|