A computer science problem by Rocco Dalto

G E T + M A I L T O D A Y \begin{array} { cccccc } & & & G & E & T \\ + & & M & A & I & L \\ \hline & T & O & D & A & Y \\ \end{array}

In the sum shown above each letter represents a digit. Let a 1 a_{1} be the maximum value for T O D A Y \overline{TODAY} , b 1 b_{1} be the minimum value for T O D A Y \overline{TODAY} and n 1 n_{1} be all possible sums of G E T + M A I L = T O D A Y \: \overline{GET} + \overline{MAIL} = \overline{TODAY} and m 1 = a 1 b 1 + n 1 m_{1} = a_{1} - b_{1} + n_{1} .

T H I S I S + M Y T I M E \begin{array} { cccccc } & T & H & I & S \\ & & & I & S \\ + & & & M & Y \\ \hline & T & I & M & E \\ \end{array}

In the second sum shown above each letter represents a digit. Let a 2 a_{2} be the maximum value for T I M E \overline{TIME} , b 2 b_{2} be the minimum value for T I M E \overline{TIME} and n 2 n_{2} be all possible sums of T H I S + I S + M Y = T I M E \: \overline{THIS} + \overline{IS} + \overline{MY} = \overline{TIME} and m 2 = a 2 b 2 + n 2 m_{2} = a_{2} - b_{2} + n_{2} .

O N E + M O R E T I M E \begin{array} { cccccc } & & & O & N & E \\ + & & M & O & R & E \\ \hline & & T & I & M & E \\ \end{array}

In the third sum shown above each letter represents a digit. Let a 3 a_{3} be the maximum value for T I M E \overline{TIME} , b 3 b_{3} be the minimum value for T I M E \overline{TIME} and n 3 n_{3} be all possible sums of O N E + M O R E = T I M E \: \overline{ONE} + \overline{MORE} = \overline{TIME} and m 3 = a 3 b 3 + n 3 m_{3} = a_{3} - b_{3} + n_{3} .

Find: m 1 + m 2 + m 3 m_{1} + m_{2} + m_{3} .

Note: You can create a program(in any language) to find m 1 m_{1} , m 2 m_{2} and m 3 m_{3} , but the program should not contain any predefined functions or procedures. That is you must create all functions and procedures and they should appear in the program, and not called from a library you created. For example, you could create your own maximum and minimum function for an array of integers and your own power function.

I wrote a program A A that when executed gets the input and writes a program B B to solve cryptograms to a text file, then I saved the text file using a different extension, complied it and ran program B B .

So, for the first cryptogram you would just need to run program A A and save the text file(using a different extension) containing program B 1 B_{1} and execute it, then run program A A again and save the text file(using a different extension) containing program B 2 B_{2} and execute it, then run program A A again and save the text file(using a different extension) containing program B 3 B_{3} and execute it.

I chose three cryptograms so that program A A can generate all three cryptograms as stated above. Writing three separate programs for each cryptogram would be tedious and that was not my intention. Essential, you just need to write program A A .

Assume I chose N N cryptograms. Write program A A to generate all N N cryptograms as stated above.


The answer is 16044.

This section requires Javascript.
You are seeing this because something didn't load right. We suggest you, (a) try refreshing the page, (b) enabling javascript if it is disabled on your browser and, finally, (c) loading the non-javascript version of this page . We're sorry about the hassle.

1 solution

Rocco Dalto
Feb 24, 2017

I used Free Pascal to construct the program:

Program A : A:

program for_brillant;

type arraytype = array[1 .. 1000] of longint;

chararray = array[1 .. 1000] of char;

var myfile:text;

s:string;

n:longint;

numwords:longint;

hold:text;

sizeword:arraytype;

procedure getinput;

var j:longint;

begin

writeln('Enter string of characters including + and =, but no spaces');

read(s);

n:= length(s);

writeln;

writeln('Enter number of words');

readln(numwords);

writeln;

writeln('Enter length of each word');

for j:= 1 to numwords do

begin

read(sizeword[j]);

end;

end;

procedure eliminate;

type darraytype = array[1 .. 300,1 .. 300] of char;

 strarray = array[1 .. 300] of string;

var j,k:longint;

notequal:boolean;

counter,counter2,total,total2,newtotal:longint;

w,z,y,x,p:chararray;

equal:boolean;

v:darraytype;

sum:strarray;

e,a,b,c,f:string;

begin

counter:= 0;

for j:= 1 to n - 1 do

begin

notequal:= true;

for k:= j + 1 to n do

begin

if (s[j] = s[k]) then

notequal:= false;

end;

if notequal and (s[j] <> '+') and (s[j] <> '=') then

begin

counter:= counter + 1;

w[counter]:= s[j];

end;

end;

total:= counter + 1;

w[total]:= s[n];

z[1]:= s[1];

counter:= 1;

for j:= 1 to n do

begin

if (s[j] = '+') or (s[j] = '=') then

begin

counter:= counter + 1;

z[counter]:= s[j + 1];

end;

end;

counter2:= 0;

for j:= 1 to counter - 1 do

begin

notequal:= true;

for k:= j + 1 to counter do

begin

if (z[j] = z[k]) then

notequal:= false;

end;

if notequal then

begin

counter2:= counter2 + 1;

y[counter2]:= z[j];

end;

end;

total2:= counter2 + 1;

y[total2]:= z[counter];

counter:= 0;

counter2:= 0;

for j:= 1 to total do

begin

notequal:= true;

for k:= 1 to total2 do

begin

if w[j] = y[k] then

begin

notequal:= false;

counter:= counter + 1;

x[counter]:= w[j];

end;

end;

if notequal then

begin

counter2:= counter2 + 1;

z[counter2]:= w[j];

end;

end;

assign(myfile, 'myfile.txt');

rewrite(myfile);

writeln(myfile,'program for brillant 3;');

writeln(myfile,'type arraytype = array[1 .. 5000] of longint;');

writeln(myfile,'var z1:arraytype;');

writeln(myfile);

writeln(myfile);

writeln(myfile,'function LINTpower(base,exponent:longint):longint;'); writeln(myfile,'var n,product:longint;');

writeln(myfile);

writeln(myfile,'begin');

  writeln(myfile,'product:= 1;');

writeln(myfile,'for n:= 1 to exponent do');

writeln(myfile,'begin');

writeln(myfile,'product:= base * product;');

writeln(myfile,'end;');

    writeln(myfile,'LINTpower:= product;');

writeln(myfile,'end;');

writeln(myfile);

writeln(myfile);

writeln(myfile, 'function minnum(a:arraytype; last:longint):longint;');

writeln(myfile,'var j,n:longint;');

writeln(myfile,'small:longint;');

writeln(myfile);

  writeln(myfile,'begin');

        writeln(myfile,'small:= a[1];');

writeln(myfile,'for j:= 2 to last do');

writeln(myfile,'begin');

writeln(myfile,'if a[j] < small then');

        writeln(myfile,'small:= a[j];');

writeln(myfile,'end;');

writeln(myfile,'minnum:= small;');

    writeln(myfile,'end;');

    writeln(myfile);

writeln(myfile,'function maxnum(a:arraytype; last:longint):longint;');

writeln(myfile,'var j,n:longint;');

writeln(myfile,'large:longint;');

  writeln(myfile,'begin');

        writeln(myfile,'large:= a[1];');

writeln(myfile,'for j:= 2 to last do');

writeln(myfile,'begin');

writeln(myfile,'if a[j] > large then');

        writeln(myfile,'large:= a[j];');

writeln(myfile,'end;');

writeln(myfile,'maxnum:= large;');

    writeln(myfile,'end;');

    writeln(myfile);

writeln(myfile,'procedure getsum; ');

writeln(myfile);

write(myfile,'var ');

for j:= 1 to counter do

begin

write(myfile,x[j],',');

end;

for j:= 1 to counter2 do

begin

if j < counter2 then

write(myfile, z[j],',')

else

write(myfile, z[j]);

end;

write(myfile,':longint;');

writeln(myfile);

write(myfile,' bool:boolean;');

writeln(myfile);

write(myfile,' j1:longint;');

writeln(myfile);

write(myfile,' a1,a2,a3,answer:longint; ');

writeln(myfile, 'sum:arraytype;');

writeln(myfile);

writeln(myfile);

writeln(myfile,'begin');

writeln(myfile);

writeln(myfile,'bool:= false;');

writeln(myfile,'j1:= 1;');

for j:= 1 to counter do

begin

writeln(myfile,'for ', x[j],':= 1 to 9 do ');

writeln(myfile,'begin')

end;

for j:= 1 to counter2 do

begin

writeln(myfile,'for ', z[j],':= 0 to 9 do ' );

writeln(myfile,'begin');

end;

for j:= 1 to counter do

begin

p[j]:= x[j];

end;

for j:= 1 to counter2 do

begin

p[j + counter]:= z[j];

end;

newtotal:= counter + counter2;

write(myfile,' if ');

for j:= 1 to newtotal - 1 do

begin

for k:= j + 1 to newtotal do

begin

if k mod 5 = 0 then

write(myfile);

writeln(myfile);

if j < newtotal - 1 then

write(myfile, '(',p[j], ' <> ', p[k],') and ')

else

write(myfile, '(',p[j], ' <> ', p[k],')');

end;

end;

write(myfile, ' then');

writeln(myfile);

writeln(myfile, 'begin' );

assign(hold,'hold.txt');

rewrite(hold);

for j:= 1 to n do

begin

if (s[j] <> '+') and (s[j] <> '=') then

begin

write(hold,s[j]);

end;

end;

reset(hold);

for j:= 1 to numwords do

begin

for k:= 1 to sizeword[j] do

begin

read(hold,v[k,j]);

end;

end;

sum[1]:= '';

for j:= 1 to numwords do

begin

if j <= numwords - 1 then

write(myfile,'z1[',j,']:= ')

else

write(myfile,'sum[j1]:= ');

for k:= 1 to sizeword[j] do

begin

str(sizeword[j] - k,e);

if k < sizeword[j] then

sum[j]:= sum[j] + ' ' + v[k,j] + ' * lintpower(10,' + e + ') + '

else

sum[j]:= sum[j] + ' ' + v[k,j] + ' * lintpower(10,' + e + ')';

end;

write(myfile,sum[j],';');

writeln(myfile);

end;

{put condition and equation here}

write(myfile,' if ');

a:= '';

for k:= 1 to numwords do

begin

if k <= numwords - 2 then

begin

str(k,b);

a:= a + 'z1[' + b + '] + '

end

else

begin

str(numwords - 1,c);

b:= 'z1[' + c + ']';

end;

f:= 'sum[j1]';

end;

write(myfile, a + b, ' = ', f);

write(myfile,' then ');

writeln(myfile,'begin');

writeln(myfile,'bool:= true;');

writeln(myfile,'j1:= j1 + 1;');

writeln(myfile,'end;');

writeln(myfile,'end;');

close(hold);

writeln(myfile);

for j:= 1 to newtotal do

begin

writeln(myfile, 'end;');

end;

writeln(myfile);

writeln(myfile,'if bool then');

writeln(myfile,'begin');

writeln(myfile,'a3:= j1 - 1;');

writeln(myfile);

writeln(myfile,'a2:= maxnum(sum,a3);');

writeln(myfile,'a1:= minnum(sum,a3);');

writeln(myfile,'writeln(''max = '', a2);');

writeln(myfile,'writeln(''min = '', a1);');

writeln(myfile,'writeln(''n = '', a3);');

writeln(myfile,'answer:= a2 - a1 + a3;');

writeln(myfile,'writeln(''answer = '', answer);');

writeln(myfile,'end;');

writeln(myfile);

writeln(myfile,' end; ');

writeln(myfile);

writeln(myfile);

writeln(myfile,'begin');

writeln(myfile,'getsum;');

writeln(myfile,'readln;');

writeln(myfile,'end.');

close(myfile);

end;

begin

getinput;

eliminate;

readln;

end.

Now run program A A and enter the data for the first cryptogram. Program A A has now written program B 1 B_{1} to the textfile "myfile.txt".

For program B 1 : B_{1}:

Go to text file "myfile.txt" and save it with a different extension( I saved it using using cryptogram3.pas).

Program cryptogram3.pas is:

program for brillant 3;

type arraytype = array[1 .. 5000] of longint;

var z1:arraytype;

function LINTpower(base,exponent:longint):longint; var n,product:longint;

begin

product:= 1;

for n:= 1 to exponent do

begin

product:= base * product;

end;

LINTpower:= product;

end;

function minnum(a:arraytype; last:longint):longint;

var j,n:longint;

small:longint;

begin

small:= a[1];

for j:= 2 to last do

begin

if a[j] < small then

small:= a[j];

end;

minnum:= small;

end;

function maxnum(a:arraytype; last:longint):longint;

var j,n:longint;

large:longint;

begin

large:= a[1];

for j:= 2 to last do

begin

if a[j] > large then

large:= a[j];

end;

maxnum:= large;

end;

procedure getsum;

var g,m,t,e,i,l,o,d,a,y:longint;

bool:boolean;

j1:longint;

a1,a2,a3,answer:longint; sum:arraytype;

begin

bool:= false;

j1:= 1;

for g:= 1 to 9 do

begin

for m:= 1 to 9 do

begin

for t:= 1 to 9 do

begin

for e:= 0 to 9 do

begin

for i:= 0 to 9 do

begin

for l:= 0 to 9 do

begin

for o:= 0 to 9 do

begin

for d:= 0 to 9 do

begin

for a:= 0 to 9 do

begin

for y:= 0 to 9 do

begin

if

(g <> m) and

(g <> t) and

(g <> e) and

(g <> i) and

(g <> l) and

(g <> o) and

(g <> d) and

(g <> a) and

(g <> y) and

(m <> t) and

(m <> e) and

(m <> i) and

(m <> l) and

(m <> o) and

(m <> d) and

(m <> a) and

(m <> y) and

(t <> e) and

(t <> i) and

(t <> l) and

(t <> o) and

(t <> d) and

(t <> a) and

(t <> y) and

(e <> i) and

(e <> l) and

(e <> o) and

(e <> d) and

(e <> a) and

(e <> y) and

(i <> l) and

(i <> o) and

(i <> d) and

(i <> a) and

(i <> y) and

(l <> o) and

(l <> d) and

(l <> a) and

(l <> y) and

(o <> d) and

(o <> a) and

(o <> y) and

(d <> a) and

(d <> y) and

(a <> y) then

begin

z1[1]:= g * lintpower(10,2) + e * lintpower(10,1) + t * lintpower(10,0);

z1[2]:= m * lintpower(10,3) + a * lintpower(10,2) + i * lintpower(10,1) + l * lintpower(10,0);

sum[j1]:= t * lintpower(10,4) + o * lintpower(10,3) + d * lintpower(10,2) + a * lintpower(10,1) + y * lintpower(10,0);

if z1[1] + z1[2] = sum[j1] then begin

bool:= true;

j1:= j1 + 1;

end;

end;

end;

end;

end;

end;

end;

end;

end;

end;

end;

end;

if bool then

begin

a3:= j1 - 1;

a2:= maxnum(sum,a3);

a1:= minnum(sum,a3);

writeln('max = ', a2);

writeln('min = ', a1);

writeln('n = ', a3);

answer:= a2 - a1 + a3;

writeln('answer = ', answer);

end;

end;

begin

getsum;

readln;

end.

Running cryptogram3.pas we obtain:

a 1 = 10584 , b 1 = 10235 , n 1 = 8 m 1 = 357 . a_{1} = 10584, \: b_{1} = 10235, \: n_{1} = 8 \implies m_{1} = \boxed{357}.

Now run program A A and enter the data for the second cryptogram. Program A A has now written program B 2 B_{2} to the textfile "myfile.txt".

For program B 2 : B_{2}:

Go to text file "myfile.txt" and save it with a different extension( I saved it using using cryptogram2.pas).

Program cryptogram2.pas is:

program for brillant 2;

type arraytype = array[1 .. 1000] of longint;

var z1:arraytype;

function LINTpower(base,exponent:longint):longint;

var n,product:longint;

begin

product:= 1;

for n:= 1 to exponent do

begin

product:= base * product;

end;

LINTpower:= product;

end;

function minnum(a:arraytype; last:longint):longint;

var j,n:longint;

small:longint;

begin

small:= a[1];

for j:= 2 to last do

begin

if a[j] < small then

small:= a[j];

end;

minnum:= small;

end;

function maxnum(a:arraytype; last:longint):longint;

var j,n:longint;

large:longint;

begin

large:= a[1];

for j:= 2 to last do

begin

if a[j] > large then

large:= a[j];

end;

maxnum:= large;

end;

procedure getsum;

var t,i,m,h,s,y,e:longint;

bool:boolean;

j1:longint;

a1,a2,a3,answer:longint; sum:arraytype;

begin

bool:= false;

j1:= 1;

for t:= 1 to 9 do

begin

for i:= 1 to 9 do

begin

for m:= 1 to 9 do

begin

for h:= 0 to 9 do

begin

for s:= 0 to 9 do

begin

for y:= 0 to 9 do

begin

for e:= 0 to 9 do

begin

if

(t <> i) and

(t <> m) and

(t <> h) and

(t <> s) and

(t <> y) and

(t <> e) and

(i <> m) and

(i <> h) and

(i <> s) and

(i <> y) and

(i <> e) and

(m <> h) and

(m <> s) and

(m <> y) and

(m <> e) and

(h <> s) and

(h <> y) and

(h <> e) and

(s <> y) and

(s <> e) and

(y <> e) then

begin

z1[1]:= t * lintpower(10,3) + h * lintpower(10,2) + i * lintpower(10,1) + s * lintpower(10,0);

z1[2]:= i * lintpower(10,1) + s * lintpower(10,0);

z1[3]:= m * lintpower(10,1) + y * lintpower(10,0);

sum[j1]:= t * lintpower(10,3) + i * lintpower(10,2) + m * lintpower(10,1) + e * lintpower(10,0);

if z1[1] + z1[2] + z1[3] = sum[j1] then begin

bool:= true;

j1:= j1 + 1;

end;

end;

end;

end;

end;

end;

end;

end;

end;

if bool then

begin

a3:= j1 - 1;

a2:= maxnum(sum,a3);

a1:= minnum(sum,a3);

writeln('max = ', a2);

writeln('min = ', a1);

writeln('n = ', a3);

answer:= a2 - a1 + a3;

writeln('answer = ', answer);

end;

end;

begin

getsum;

readln;

end.

Running cryptogram2.pas we obtain:

a 2 = 9587 , b 2 = 1420 , n 2 = 308 m 2 = 8475 . a_{2} = 9587, \: b_{2} = 1420, \: n_{2} = 308 \implies m_{2} = \boxed{8475}.

Now run program A A and enter the data for the third cryptogram. Program A A has now written program B 3 B_{3} to the textfile "myfile.txt".

For program B 3 : B_{3}:

Go to text file "myfile.txt" and save it with a different extension( I saved it using using cryptogram.pas).

Program cryptogram.pas is:

program for brillant 1;

type arraytype = array[1 .. 300] of longint;

var z1:arraytype;

function LINTpower(base,exponent:longint):longint;

var n,product:longint;

begin

product:= 1;

for n:= 1 to exponent do

begin

product:= base * product;

end;

LINTpower:= product;

end;

function minnum(a:arraytype; last:longint):longint;

var j,n:longint;

small:longint;

begin

small:= a[1];

for j:= 2 to last do

begin

if a[j] < small then

small:= a[j];

end;

minnum:= small;

end;

function maxnum(a:arraytype; last:longint):longint;

var j,n:longint;

large:longint;

begin

large:= a[1];

for j:= 2 to last do

begin

if a[j] > large then

large:= a[j];

end;

maxnum:= large;

end;

procedure getsum;

var o,t,m,n,r,i,e:longint;

bool:boolean;

j1:longint;

a1,a2,a3,answer:longint; sum:arraytype;

begin

bool:= false;

j1:= 1;

for o:= 1 to 9 do

begin

for t:= 1 to 9 do

begin

for m:= 1 to 9 do

begin

for n:= 0 to 9 do

begin

for r:= 0 to 9 do

begin

for i:= 0 to 9 do

begin

for e:= 0 to 9 do

begin

if

(o <> t) and

(o <> m) and

(o <> n) and

(o <> r) and

(o <> i) and

(o <> e) and

(t <> m) and

(t <> n) and

(t <> r) and

(t <> i) and

(t <> e) and

(m <> n) and

(m <> r) and

(m <> i) and

(m <> e) and

(n <> r) and

(n <> i) and

(n <> e) and

(r <> i) and

(r <> e) and

(i <> e) then

begin

z1[1]:= o * lintpower(10,2) + n * lintpower(10,1) + e * lintpower(10,0);

z1[2]:= m * lintpower(10,3) + o * lintpower(10,2) + r * lintpower(10,1) + e * lintpower(10,0);

sum[j1]:= t * lintpower(10,3) + i * lintpower(10,2) + m * lintpower(10,1) + e * lintpower(10,0);

if z1[1] + z1[2] = sum[j1] then begin

bool:= true;

j1:= j1 + 1;

end;

end;

end;

end;

end;

end;

end;

end;

end;

if bool then

begin

a3:= j1 - 1;

a2:= maxnum(sum,a3);

a1:= minnum(sum,a3);

writeln('max = ', a2);

writeln('min = ', a1);

answer:= a2 - a1 + a3;

writeln('answer = ', answer);

end;

end;

begin

getsum;

end.

Running cryptogram.pas we obtain:

a 3 = 9480 , b 3 = 2310 , n 3 = 42 m 3 = 7212 . a_{3} = 9480, \: b_{3} = 2310, \: n_{3} = 42 \implies m_{3} = \boxed{7212}.

m 1 + m 2 + m 3 = 16044 . \implies m_{1} + m_{2} + m_{3} = \boxed{16044}.

0 pending reports

×

Problem Loading...

Note Loading...

Set Loading...