+ T M O G A D E I A T L Y
In the sum shown above each letter represents a digit. Let a 1 be the maximum value for T O D A Y , b 1 be the minimum value for T O D A Y and n 1 be all possible sums of G E T + M A I L = T O D A Y and m 1 = a 1 − b 1 + n 1 .
+ T T H I I I M M S S Y E
In the second sum shown above each letter represents a digit. Let a 2 be the maximum value for T I M E , b 2 be the minimum value for T I M E and n 2 be all possible sums of T H I S + I S + M Y = T I M E and m 2 = a 2 − b 2 + n 2 .
+ M T O O I N R M E E E
In the third sum shown above each letter represents a digit. Let a 3 be the maximum value for T I M E , b 3 be the minimum value for T I M E and n 3 be all possible sums of O N E + M O R E = T I M E and m 3 = a 3 − b 3 + n 3 .
Find: m 1 + m 2 + m 3 .
Note: You can create a program(in any language) to find m 1 , m 2 and 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 that when executed gets the input and writes a program B to solve cryptograms to a text file, then I saved the text file using a different extension, complied it and ran program B .
So, for the first cryptogram you would just need to run program A and save the text file(using a different extension) containing program B 1 and execute it, then run program A again and save the text file(using a different extension) containing program B 2 and execute it, then run program A again and save the text file(using a different extension) containing program B 3 and execute it.
I chose three cryptograms so that program 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 .
Assume I chose N cryptograms. Write program A to generate all N cryptograms as stated above.
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.
Problem Loading...
Note Loading...
Set Loading...
I used Free Pascal to construct the program:
Program 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;
var j,k:longint;
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,'for n:= 1 to exponent do');
writeln(myfile,'begin');
writeln(myfile,'end;');
writeln(myfile,'end;');
writeln(myfile);
writeln(myfile);
writeln(myfile, 'function minnum(a:arraytype; last:longint):longint;');
writeln(myfile,'var j,n:longint;');
writeln(myfile);
writeln(myfile,'begin');
writeln(myfile,'end;');
writeln(myfile,'function maxnum(a:arraytype; last:longint):longint;');
writeln(myfile,'var j,n:longint;');
writeln(myfile,'begin');
writeln(myfile,'end;');
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 and enter the data for the first cryptogram. Program A has now written program B 1 to the textfile "myfile.txt".
For program 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 = 1 0 5 8 4 , b 1 = 1 0 2 3 5 , n 1 = 8 ⟹ m 1 = 3 5 7 .
Now run program A and enter the data for the second cryptogram. Program A has now written program B 2 to the textfile "myfile.txt".
For program 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 = 9 5 8 7 , b 2 = 1 4 2 0 , n 2 = 3 0 8 ⟹ m 2 = 8 4 7 5 .
Now run program A and enter the data for the third cryptogram. Program A has now written program B 3 to the textfile "myfile.txt".
For program 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 = 9 4 8 0 , b 3 = 2 3 1 0 , n 3 = 4 2 ⟹ m 3 = 7 2 1 2 .
⟹ m 1 + m 2 + m 3 = 1 6 0 4 4 .