Simo K. Kivelä / 29.9.1999

Kexleruksen tehtävä

Simon Kexlerus oli Turun Akatemian ensimmäinen matematiikan professori 1640 - 1669. Seuraava on eräs Kexleruksen tehtävä Turun Aboa Vetus -museon näyttelyn mukaan:

Sinulla on viinejä, jotka maksavat 3, 5, 8 ja 10 markkaa litralta. Tee 10 litraa sekoitusta, joka maksaa 6 markkaa litralta. [Oletettaneen lisäksi, että sekoitukseen käytetään vain täysiä yhden litran pulloja.]

•Ratkaisu Mathematicalla:

In[1]:=

Remove["Global`*"]

Eri viinilajeja otetaan a, b, c ja dFormBox[Cell[], TraditionalForm] litraa. Kokonaismäärän tulee olla kymmenen litraa:

In[2]:=

litrat = a + b + c + d == 10

Out[2]=

a + b + c + d == 10

Kymmenen litran hinta saadaan toisaalta eri viinilajien hintojen perusteella ja toisaalta sen tulee olla 6 markkaa litralta:

In[3]:=

rahat = 3 a + 5 b + 8 c + 10 d == 60

Out[3]=

3 a + 5 b + 8 c + 10 d == 60

Listataan kaikki vaihtoehdot viinimääriksi, kun kutakin viinilajia on otettava vähintään 0 litraa ja enintään 10 litraa. Tässä vaiheessa ei vielä välitetä edellä muodostetuista rajoitusehdoista. Koska vaihtoehtoja tulee paljon, katsotaan varovaisesti ensin, millainen vaihtoehtolista saadaan, jos viinejä on vain kolmea lajia ja kutakin niistä otetaan vähintään 0 ja enintään 2 litraa:

In[4]:=

vaihtoehdot = Table[{a, b, c}, {a, 0, 2}, {b, 0, 2}, {c, 0, 2}]

Out[4]=

{{{{0, 0, 0}, {0, 0, 1}, {0, 0, 2}}, {{0, 1, 0}, {0, 1, 1}, {0, 1, 2}}, {{0, 2, 0}, {0, 2, 1}, ...  0}, {2, 0, 1}, {2, 0, 2}}, {{2, 1, 0}, {2, 1, 1}, {2, 1, 2}}, {{2, 2, 0}, {2, 2, 1}, {2, 2, 2}}}}

Hieman  selkeämmässä muodossa:

In[5]:=

vaihtoehdot // TableForm

Out[5]//TableForm=

0 0 0
0 0 1
0 0 2
0 1 0
0 1 1
0 1 2
0 2 0
0 2 1
0 2 2
1 0 0
1 0 1
1 0 2
1 1 0
1 1 1
1 1 2
1 2 0
1 2 1
1 2 2
2 0 0
2 0 1
2 0 2
2 1 0
2 1 1
2 1 2
2 2 0
2 2 1
2 2 2

Vaihtoehdoista voidaan saada myös vain yksinkertainen lista:

In[6]:=

Flatten[vaihtoehdot, 2]

Out[6]=

{{0, 0, 0}, {0, 0, 1}, {0, 0, 2}, {0, 1, 0}, {0, 1, 1}, {0, 1, 2}, {0, 2, 0}, {0, 2, 1}, {0, 2 ... {2, 0, 0}, {2, 0, 1}, {2, 0, 2}, {2, 1, 0}, {2, 1, 1}, {2, 1, 2}, {2, 2, 0}, {2, 2, 1}, {2, 2, 2}}

Ja sitten varsinaisen tapauksen vaihtoehtolista edellä olevan mallin mukaisesti yksinkertaiseksi listaksi muunnettuna; puolipiste komennon lopussa estää tulostuksen, ts. lauseke vain lasketaan, mutta sitä ei näytetä:

In[7]:=

vaihtoehdot = Flatten[Table[{a, b, c, d}, {a, 0, 10}, {b, 0, 10}, {c, 0, 10}, {d, 0, 10}], 3] ;

Tässä on vaihtoehtoja kaikkiaan

In[8]:=

Length[vaihtoehdot]

Out[8]=

14641

Tarkoituksena on poimia tästä listasta ne vaihtoehdot, jotka toteuttavat alussa muodostetut kaksi ehtoa. Tätä varten muodostetaan funktio, joka saa arvon tosi, jos sen argumentti toteuttaa molemmat ehdot:

In[9]:=

ehto[{a_, b_, c_, d_}] = rahat && litrat

Out[9]=

3 a + 5 b + 8 c + 10 d == 60 && a + b + c + d == 10

Tällöin on esimerkiksi

In[10]:=

ehto[{1, 2, 3, 4}]

Out[10]=

False

Poimitaan ne vaihtoehdot, joilla ehto toteutuu:

In[11]:=

tulos = Select[vaihtoehdot, ehto]

Out[11]=

{{0, 8, 0, 2}, {1, 5, 4, 0}, {2, 4, 3, 1}, {3, 3, 2, 2}, {4, 0, 6, 0}, {4, 2, 1, 3}, {5, 1, 0, 4}}

Ratkaisuja löytyy siis kaikkiaan kahdeksan. Jos vaaditaan, että jokaista viinilajia on käytettävä, ratkaisuja on vain kolme:

In[12]:=

Select[tulos, Apply[Min, #] > 0 &]

Out[12]=

{{2, 4, 3, 1}, {3, 3, 2, 2}, {4, 2, 1, 3}}


Converted by Mathematica  (May 9, 2003)