Positiestelsels, rekenen en streepjescodes

advertisement
Positiestelsels, rekenen en streepjescodes
Dion Coumans
Mai Gehrke
Lorijn van Rooijen
1
Introductie
In dit dictaat ‘Positiestelsels, rekenen en streepjescodes’ verdiepen we ons in de wereld van
de getallen. In het eerste hoofdstuk nemen we onze manier om getallen te noteren onder
de loep en analyseren de ‘simpele bewerkingen’ optellen en vermenigvuldigen. In de twee
hoofdstukken daarna zie je dat deze abstracte theorie aan de basis staat van een aantal
alledaagse toepassingen.
Een opmerking vooraf: We werken in deze cursus alleen met natuurlijke getallen. Dat
zijn de getallen die je gebruikt om te tellen: 0, 1, 2, 3, . . .. Spreken we van ‘een getal’, dan
bedoelen we een natuurlijk getal.
Mocht je na deze cursus nog vragen hebben, bel of mail ons dan gerust. Vind je de telefoonnummers er vreemd uit zien? Ze zijn hexadecimaal geschreven! Na hoofdstuk 3 weet
je wat dat betekent en kun je ze ontcijferen (zet er na het ontcijferen nog een nul voor om
ons te bellen).
Veel plezier!
Dion Coumans
coumans@math.ru.nl
E85D908
Mai Gehrke
m.gehrke@math.ru.nl
E85DA64
Lorijn van Rooijen lorijn.vanrooijen@student.ru.nl
1
2
Positiestelsels
In tegenstelling tot het oude Rome, waar verschillende tekens bestonden voor 1, 5, 10, 50,
100, 500 en 1000, combineren wij tegenwoordig de tien symbolen 0, . . . , 9 om getallen te
noteren. Hierbij gebruiken we het zogenaamde positiestelsel. In een positiestelsel hangt de
betekenis van een symbool af van zijn plaats in het getal.
Opgave 1. Hoeveel verschillende Romeinse getallen kun je noteren met I (1), V (5),
X (10), L (50), C (100), D (500) en M (1000)? Hoeveel verschillende getallen kun je
opschrijven met 0, . . . , 9?
De symbolen 0, . . . , 9 die wij gebruiken zijn eigenlijk nogal willekeurig. In dit hoofdstuk
zullen we zien wat een algemeen positiestelsel is en ontdekken we dat je in zo’n stelsel
makkelijk kunt rekenen.
Wat is een positiestelsel nu precies? Het maken van een positiestelsel gaat in vier stappen:
i) Eerst kiezen we een aantal symbolen. We kunnen bijvoorbeeld de bekende tien symbolen nemen: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9.
ii) We geven één van de symbolen de betekenis ‘niets’. Dit lijkt misschien zonde: als
een symbool voor ‘niets’ staat, waarom gebruiken we het dan? Later zullen we zien
dat het positiestelsel juist zo krachtig is doordat we ‘niets’ aan kunnen geven. Wij
gebruiken hiervoor het symbool 0.
iii) De overige symbolen worden gebruikt om zo ver mogelijk te tellen:
1→2→3→4→5→6→7→8→9
iv) Het volgende getal in de keten noteren we met 10. Het symbool 1 in stap (iii)
betekende één. Nu er een 0 achter de 1 staat, krijgt het symbool een andere betekenis:
het betekent één keer ‘het aantal symbolen dat we gebruiken’. Laten we dit aantal
noteren met G. In ons voorbeeld is G gelijk aan tien. De betekenis van 10 is dus
0 + G · 1.
Nu kunnen we zo doorgaan: als we bij 10 één eenheid optellen krijgen we 11 = 1+G·1,
als we bij 11 één eenheid optellen krijgen we 12 = 2 + G · 1, en door zo verder te gaan
krijgen we ook 13, 14, . . . , 19.
Als we nu bij 19 nog 1 optellen, hogen we de 9 dus met 1 op, en krijgen we weer
een keer ‘het aantal symbolen dat we gebruiken’. Dus krijgen we 0 + G · 2 = 20.
Zo verder krijgen we ook 21, 22, . . . , 99. Bij 99 aangekomen, tellen we 1 bij 9 op,
zodat we 0 eenheden en nog een keer ‘het aantal symbolen dat we gebruiken’ krijgen.
Het meest rechtse symbool moet dus een 0 worden. Maar nu hebben we in totaal G
keren G en dit kunnen we niet met alleen de tweede plek aangeven. We krijgen nu
100 = 0 + G · (0 + G · 1), etc. Bijvoorbeeld:
347 = 7 + G · (4 + G · 3)
10499 = 9 + G · (9 + G · (4 + G · (0 + G · 1)))
2
Door met de symbolen 0, 1, . . . , 9 te beginnen, krijgen we de (gebruikelijke) decimale notatie
voor getallen. Wat gebeurt er als we een andere verzameling symbolen nemen?
Opgave 2. Laten we de symbolen 0, 1, 2 nemen. Wat zijn de eerste dertig getallen in
dit positiestelsel? Hoe wordt het getal dat we in dit systeem als 122 schrijven, in ons
positiestelsel met tien symbolen geschreven?
We kunnen natuurlijk ook met meer dan tien symbolen beginnen.
Opgave 3. Laten we de symbolen 0, 1, 2, . . . , 9, X nemen. Hoe worden de eerste twintig
getallen in dit positiestelsel geschreven?
Het aantal symbolen dat je gebruikt in een positiestelsel noemen we het grondtal of de basis
van het postiestelsel. Bovenstaande opgave ging dus over het positiestelsel met grondtal
elf, oftewel over een elftallig stelsel. In het vervolg geven we met een subscript aan in welke
basis een getal is geschreven, 2003 is bijvoorbeeld een drietallig genoteerd getal.
Ons talstelsel met grondtal 10 is geen West-Europese vinding. Het is in de middeleeuwen
in Arabië ontwikkeld. Vermoedelijk hebben de Arabieren het weer van de Indiërs geleerd.
Met de opbloeiende handel in de twaalfde eeuw is het nieuwe talstelsel ook in Europa
bekend geworden, waar het langzaam het oude Romeinse talstelsel heeft verdrongen.
2.1
Van G-tallige naar tientallige notatie
We hebben nu gezien dat je voor een willekeurig grondtal G, G-tallig getallen kunt schrijven.
In de volgende opgaven ontdek je hoe je van een G-tallig geschreven getal, zijn tientallige
notatie kunt bepalen.
Opgave 4. Hoe schrijf je het getal 2103 tientallig? En X3X11 ?
Opgave 5. Hoe bepaal je, voor een willekeurig natuurlijk getal G en een getal a2 a1 a0 in
het G-tallig stelsel, de tientallige notatie van a2 a1 a0 ?
a2 a1 a0 (G-tallig) = . . . . . . . . . . . . . . . . . . . . . (tientallig)
Opgave 6. Met de hierboven gevonden formule kun je driecijferige getallen in een G-tallig
stelsel omzetten naar het tientallig stelsel, maar we willen natuurlijk graag een nog algemenere formule hebben. Hoe bepaal je, voor een getal G en een getal an an−1 . . . a1 a0 in
het G-tallig stelsel, de notatie voor an an−1 . . . a1 a0 in het tientallig stelsel?
an an−1 . . . a1 a0 (G-tallig) = . . . . . . . . . . . . . . . . . . . . . . . . (tientallig)
2.2
Optellen en vermenigvuldigen
Op de basisschool leer je hoe je getallen kunt optellen en vermenigvuldigen. Door het
positiestelsel hebben we een handige methode om deze operaties uit te voeren. In het
Romeinse talstelsel is optellen (laat staan vermenigvuldigen) veel lastiger. Probeer de
volgende opgave maar eens te maken zonder de getallen eerst om te rekenen naar ons
hedendaagse tientallig stelsel.
3
Opgave 7. Bereken de som van de twee Romeinse getallen MCMXCIX en MCCXXIV.
(I = 1, V = 5, X = 10, L = 50, C = 100, D = 500, M = 1000)
In het positiestelsel kun je getallen optellen door ze onder elkaar te zetten:
+
231
84
315
10
Deze methode werkt doordat de optelling en vermenigvuldiging de volgende eigenschappen
hebben:
i) De optelling is associatief : voor alle getallen n, m, k,
(n + m) + k = n + (m + k)
ii) De optelling is commutatief : voor alle getallen n, m,
n+m=m+n
iii) De vermenigvuldiging is commutatief : voor alle getallen n, m,
n·m=m·n
iv) De vermenigvuldiging distribueert over de optelling: voor alle getallen n, m, k,
m · (n + k) = m · n + m · k
en (n + k) · m = n · m + k · m
v) Er is een delingsalgoritme, voor alle getallen n, m met m 6= 0, zijn er unieke getallen
q, r zodat
n = q · m + r en 0 ≤ r < m
We illustreren de rol van deze regels aan de hand van bovenstaand voorbeeld. Als je 231
en 84 wilt optellen, bereken je 1 + 10 · (3 + 10 · 2) + 4 + 10 · 8 (vanwege de betekenis van
de notatie in een positiestelsel). Waarom is dat gelijk aan 5 + 10 · (1 + 10 · 3) (= 315)?
Vanwege bovenstaande vijf regels! Kijk maar hieronder. Omdat de optelling associatief is,
hoeven we ons als we optellen niet druk te maken over de haakjes.
231 + 84 =
=
=
=
=
=
=
=
=
=
=
1 + 10 · (3 + 10 · 2) + 4 + 10 · 8
1 + 4 + 10 · (3 + 10 · 2) + 10 · 8
1 + 4 + 10 · (3 + 10 · 2 + 8)
1 + 4 + 10 · (3 + 8 + 10 · 2)
5 + 10 · (11 + 10 · 2)
5 + 10 · (1 · 10 + 1 + 10 · 2)
5 + 10 · (1 + 1 · 10 + 10 · 2)
5 + 10 · (1 + 10 · 1 + 10 · 2)
5 + 10 · (1 + 10 · (1 + 2))
5 + 10 · (1 + 10 · 3)
315
4
(+ commutatief)
(· distribueert over +)
(+ commutatief)
(optellen van getallen kleiner dan 10)
(delingsalgoritme)
(+ commutatief)
(· commutatief)
(· distribueert over +)
(optellen van getallen kleiner dan 10)
Opgave 8. Bereken 77 + 588 op bovenstaande wijze. Schrijf bij elke stap op welke regel
je toepast. Geeft dit dezelfde uitkomst als de ‘onder-elkaar-zet-methode’ ?
De vijf regels voor de optelling hangen niet af van het grondtal 10 en gelden in elk positiestelsel. De ‘onder-elkaar-zet-methode’ om getallen op te tellen kun je dus ook in elk
positiestelsel gebruiken.
Opgave 9. Bereken:
222
+ 111
+
5X 7
36
3
11
Opgave 10. Schrijf de getallen uit de vorige opgave tientallig om je antwoorden te controleren.
Met wat meer werk kun je laten zien dat ook de onder-elkaar-zet-methode om twee getallen
te vermenigvuldigen correct is (in elk G-tallig stelsel). Pas deze methode toe in de volgende opgave en vertaal de getallen weer naar het tientallig stelsel om je antwoorden te
controleren.
Opgave 11. Bereken:
201
×
21
3
22
× 22
3
72
× 65
11
5
2.3
Van tientallige naar G-tallige notatie
In paragraaf 2.1 heb je ontdekt hoe je de tientallige notatie van een G-tallig geschreven
getal kunt bepalen. In deze paragraaf leggen we uit hoe je het omgekeerde kunt doen: Hoe
bepaal je de G-tallige notatie van een tientallig geschreven getal?
Opgave 12. Hoe schrijf je het getal 1810 drietallig? En 20010 elftallig? En 12110 drietallig?
Zoals we hebben gezien zijn er, voor alle getallen n, m met m 6= 0, unieke getallen q, r
zodat
n = q · m + r en 0 ≤ r < m.
Dit delingsalgoritme speelt een belangrijke rol bij het bepalen van de G-tallige notatie van
een (tientallig geschreven) getal. Voor een gegeven grondtal G en een getal n dat tientallig
is geschreven, is de G-tallige notatie voor n een rijtje cijfers ak ak−1 . . . a1 a0 , waarbij alle
getallen a0 , a1 , . . . , ak strikt kleiner zijn dan G en
n = a0 + G · (a1 + G · (a2 + . . . + G · (ak−1 + G · ak ) . . .))
Dit betekent dat we a0 kunnen vinden door het delingsalgoritme toe te passen op n en G,
m.a.w. we schrijven
n = q · G + r.
Het getal a0 is dan de rest r van deze deling en a1 + G · (a2 + . . . + G · (ak−1 + G · ak ) . . .)
is het getal q.
Zodra we q gevonden hebben, kunnen we a1 vinden door het delingsalgoritme toe te passen
op q en G, enz.
Deze procedure geeft een methode om de G-tallige notatie te vinden van een tientallig
geschreven getal n:
n = q0 · G + r0 het symbool a0 voor r0 in het G-tallig stelsel is het meest rechtse cijfer
q0 = q1 · G + r1 het symbool a1 voor r1 in het G-tallige stelsel is het tweede cijfer
·
·
·
qk−1 = 0 · G + rk het symbool ak voor rk in het G-tallige stelsel is het meeste linkse cijfer.
Opgave 13. Geef de vijftallige notatie van 121510 .
Opgave 14. Geef de elftallige notatie van 121510 .
Opgave 15. Geef de negentallige notatie van 54710 .
Opgave 16. Geef de drietallige notatie van 54710 .
6
3
Het binaire stelsel
In een computer is veel informatie opgeslagen, denk bijvoorbeeld aan teksten, plaatjes,
kleuren en programma’s. Om dit soort informatie te kunnen opslaan, moeten de gegevens
op een zodanige manier worden gecodeerd dat de computer er mee kan werken. Computers
werken op elektriciteit en de enige mogelijkheid om iets te coderen is door verschillende hoeveelheden stroom door delen van de computer te laten gaan. Om een duidelijk onderscheid
te hebben tussen de verschillende mogelijkheden wordt er met slechts twee hoeveelheden
gewerkt: geen capaciteit (0) en volle capaciteit (1). Zodoende wordt alles in een computer
met twee symbolen gecodeerd.
Gelukkig hebben wij een goed systeem om getallen met twee symbolen te noteren: het
positiestelsel op twee symbolen. We noemen dit de binaire notatie.
Opgave 17. Schrijf de eerste twintig getallen in de binaire notatie.
Als een computer voor ons gaat rekenen moet hij dus de decimale notatie naar de binaire
notatie vertalen en andersom.
Opgave 18. Geef de formule voor het vertalen van de binaire naar de decimale notatie.
Opgave 19. Schrijf de volgende binaire getallen in decimale notatie: 1012 , 1101012 , 11002 .
Opgave 20. Beschrijf het algoritme om getallen in de decimale notatie naar hun binaire
notatie te vertalen.
Opgave 21. Schrijf de volgende decimale getallen binair: 710 , 2510 , 12810 , 20010 .
Zoals we hebben gezien, kun je in een positiestelsel eenvoudig optellen en vermenigvuldigen.
Opgave 22. Bereken in het binaire positiestelsel:
+
110101
1100
1100
×
101
2
2
Opgave 23. Vertaal de getallen van de vorige opgave naar hun decimale schrijfwijze om
je antwoorden te controleren.
7
In opgave 21 heb je (200)10 binair geschreven. Dit geeft een getal met acht cijfers in plaats
van de drie cijfers in 200. Als je het decimale getal tien triljoen (1010 ) binair wilt schrijven,
krijg je een behoorlijk lang getal:
230 = (23 )10 = 810 ≤ 1010 ≤ 1610 = 240
dus de binaire notatie van 1010 heeft tussen de 30 en 40 cijfers.
In zulke lange getallen treedt sneller een leesfout op en ook zijn ze erg onhandig als programmeurs ze moeten invoeren. Om de getallen korter te kunnen noteren, wordt er gewerkt
met het hexadecimale stelsel. Dit is het positiestelsel met basis 16. We gebruiken hiervoor
de volgende symbolen:
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F.
Opgave 24. Schrijf de eerste twintig getallen in hexadecimale notatie.
Opgave 25. Schrijf 94D316 in decimale en 10010 in hexadecimale notatie.
Opgave 26. Schrijf 9A3B16 binair en 10110012 hexadecimaal.
Hoe heb je de vorige opgave aangepakt? Om om te rekenen van de binaire naar de hexadecimale notatie kun je natuurlijk het binaire getal eerst tientallig schrijven en vervolgens
deze tientallige notatie vertalen naar een hexadecimale notatie. Doordat 16 = 24 is er
echter een directe methode: elk hexadecimaal cijfer correspondeert met een blok van vier
binaire cijfers. Zo schrijf je 7C4F16 als volgt in binaire notatie:
7
C
4
F
0111 1100 0100 1111
Opgave 27. Leg uit waarom bovenstaande vertaalmethode van de hexadecimale naar de
binaire notatie werkt. Zie je nu ook hoe je een binair getal rechtstreeks hexadecimaal kunt
schrijven?
Opgave 28. Schrijf je telefoonnummer in binaire en hexadecimale notatie! Kun je nu ook
onze telefoonnummers ontcijferen?
Opgave 29. Bij true color worden kleuren op het beeldscherm van de computer weergegeven
door een RGB-code. Een RGB-code bestaat uit drie bytes (een byte is een rijtje van 8
nullen en enen), één voor Rood, één voor Groen en één voor Blauw (eigenlijk Red, Green
en Blue). Voor RGB-codes gebruikt men soms de decimale notatie en soms de hexadecimale. In de decimale notatie is een RGB-code een rijtje van drie getallen tussen 0 en 255,
bijvoorbeeld 210.35.106. Hexidecimaal noteert men dat als D2.23.6A. De grootte van elk
van de drie getallen geeft de intensiteit van de kleur weer.
i) Hoeveel kleuren zijn er in het true color schema?
ii) De RGB-code voor wit is FF.FF.FF. Wat zijn de RGB-codes voor rood, paars, zwart
en grijs?
iii) Als de som van twee codes gelijk is aan FF.FF.FF, dan heten deze kleuren complementair aan elkaar. Wat zijn de complementaire kleuren van rood, groen en blauw?
Je kunt een binair-decimaal-hexadecimaal omzetter op internet vinden op:
http://www.mathsisfun.com/binary-decimal-hexadecimal-converter.html
8
4
Streepjescodes
Sinds de jaren 70 worden streepjescodes gebruikt op producten in supermarkten en tegenwoordig zijn vrijwel alle producten voorzien van een streepjescode. Met dit systeem wordt
automatisch bijgehouden hoe het staat met de voorraad van de winkel. Bij de kassa wordt
je aankoop gescand en de scanner vertaalt de streepjescode in een rijtje cijfers. In dit rijtje
cijfers zit informatie over het product ‘verborgen’ waardoor de computer weet welk product
er verkocht is. Als we het in het vervolg over een streepjescode hebben, dan bedoelen we
het bijbehorende rijtje cijfers.
Bij het inscannen van de code zouden er fouten kunnen optreden: de scanner kan één
van de getallen verkeerd inlezen. Toch gebeurt het niet vaak dat er opeens vreemde producten op je kassabon verschijnen. Dit komt doordat er een controlesysteem is ingebouwd
in streepjescodes. Dit systeem berust op het feit dat niet elk rijtje cijfers voorkomt als
streepjescode. Een geldige streepjescode voldoet aan de volgende regel: Neem driemaal de
som van de cijfers op de even posities (van linksaf geteld!). Tel hierbij op de som van de
cijfers op de oneven posities. Dit getal moet deelbaar zijn door tien.
Kijken we naar bovenstaand voorbeeld, dan moet het getal
3 · (2 + 4 + 6 + 8 + 0 + 2) + (1 + 3 + 5 + 7 + 9 + 1 + 8)
deelbaar zijn door 10. Inderdaad, de som geeft 100 en 100 = 10 · 10.
Leest de scanner een ‘ongeldige code’, dan is er blijkbaar iets misgegaan. De cassière
ziet dat het scannen niet is gelukt en kan het opnieuw proberen, of de code met de hand
intypen.
Opgave 30. Zoek een aantal producten met een streepjescode en controleer of de streepjescodes allemaal geldig zijn.
Opgave 31. Probeer in te zien dat het vervangen van één cijfer door een ander cijfer in
een geldige streepjescode altijd een ongeldige code oplevert.
Bovenstaande streepjescode is een voorbeeld van een European Article Number (EAN).
Vrijwel alle producten in de Nederlandse winkels hebben zo’n nummer. Deze codering is
een uitbreiding van de Universal Product Code (UPC), die sinds 1973 wordt gebruikt om
artikelen te coderen. Een EAN bestaat uit dertien cijfers. De eerste twaalf cijfers geven
aan wie de fabrikant is en welk product het is. Het laatste cijfer zorgt dat de streepjescode
een geldige streepjescode wordt.
9
Opgave 32. Laat zien dat elk twaalfcijferige code met één cijfer aan te vullen is tot een
geldige (dertiencijferige) streepjescode.
Meestal worden streepjescodes met een scanner gelezen, maar het kan gebeuren dat een
etiket beschadigd is en de code met de hand moet worden ingevoerd. Bij het overtypen
van een rijtje cijfers kan het gebeuren dat twee opeenvolgende cijfers worden verwisseld.
Helaas zorgt zo’n verwisseling er niet altijd voor dat een geldige code verandert in een
ongeldige code.
Opgave 33. Laat aan de hand van een voorbeeld zien dat het verwisselen van twee naast
elkaar gelegen cijfers in een geldige streepjescode soms weer tot een geldige streepjescode
kan leiden.
Het EAN is een voorbeeld van een foutherkennende codering. Dit is een methode om aan
een rijtje (cijfers) extra informatie toe te voegen zodat ingeslopen fouten kunnen worden
ontdekt. Bij het EAN is die ‘extra informatie’ het cijfer waarmee de twaalfcijferige code
wordt aangevuld tot een geldige streepjescode. Door het toevoegen van dat extra cijfer, de
zogenaamde ‘check digit’, kunnen bepaalde fouten (zoals het verkeerd lezen van één van
de cijfers) worden herkend.
Een ander voorbeeld van een foutherkennende codering die gebruik maakt van een check
digit is de international standard book number (ISBN). Een ISBN bestaat uit tien cijfers.
De eerste negen cijfers geven informatie over het boek (zoals de uitgever en de taal), het
laatste cijfer zorgt voor de foutherkenning. Je kunt als volgt controleren of een gegeven rijtje
van tien cijfers een geldig ISBN is: Neem 10 maal het eerste cijfer, 9 maal het tweede cijfer,
8 maal het derde cijfer, . . . , 1 maal het laatste cijfer. Tel dit alles bij elkaar op. Het rijtje is
een geldig ISBN als het resultaat deelbaar is door elf. Zo is bijvoorbeeld 0-306-40615-2 een
geldige ISBN code, want 10·0+9·3+8·0+7·6+6·4+5·0+4·6+3·1+2·5+1·2 = 132 = 12·11.
Opgave 34. Is elk negencijferig rijtje met één cijfer aan te vullen tot een geldige ISBN
code?
Je hebt zojuist als het goed is ontdekt dat niet elk negencijferig rijtje aan te vullen is tot
een geldige ISBN code. Het gaat bijvoorbeeld mis bij het rijtje 000000006. Om op een
elfvoud uit te komen, zou je op de laatste plaats 10 neer willen zetten, maar we hebben
alleen de cijfers 0 t/m 9. Dit probleem wordt opgelost door op de laatste plaats in de ISBN
code ook het symbool X toe te laten. Deze X lezen we als 10. Het rijtje 000000006 levert
dan de geldige ISBN-code 000000006X. Door als check digit de cijfers 0 t/m 9 én het
symbool X te gebruiken, kun je van elk negencijferig rijtje een geldige ISBN-code maken.
Opgave 35. Probeer in te zien dat het vervangen van één cijfer door een ander cijfer in
een geldige ISBN-code altijd een ongeldige code oplevert.
Net als EAN, herkent ISBN dus het verkeerd invoeren van één van de cijfers. ISBN is
echter nog sterker; het herkent ook het verwisselen van twee naast elkaar gelegen cijfers.
Opgave 36. Probeer in te zien dat het verwisselen van twee naast elkaar gelegen cijfers
in een geldige ISBN code altijd een ongeldige code oplevert.
10
Bovenstaande ISBN codering wordt ook wel ISBN-10 genoemd. Deze codering werd gebruikt tot 31 december 2006. Sindsdien werkt men met ISBN-13, een codering die hetzelfde
werkt als EAN. Nadeel van deze codering is dat hij minder fouten herkent dan de ISBN-10.
Je hebt hierbij echter genoeg aan de cijfers 0 t/m 9 als check digit en tegenwoordig worden
de meeste codes met een scanner gelezen, waardoor het verwisselen van twee naast elkaar
gelegen cijfers niet vaak zal voorkomen.
Bronnen
• Keune, F., Getallen - van natuurlijk naar imaginair, Den Haag 2009
• Ratio, http://www.ratio.ru.nl
11
5
Antwoorden
1. In beide gevallen kun je oneindig veel verschillende getallen opschrijven. Bij de
Romeinse notatie worden de getallen echter al snel heel lang.
2. 0, 1, 2, 10, 11, 12, 20, 21, 22, 100, 101, 102, 110, 111, 112, 120, 121, 122, 200, 201, 202, 210,
211, 212, 220, 221, 222, 1000, 1001, 1002
1223 wordt tientallig geschreven als 17
3. 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, X, 10, 11, 12, 13, 14, 15, 16, 17, 18
4. 2103 tientallig geschreven is: 0 + 3 · (1 + 3 · 2) = 21
X3X11 tientallig geschreven is: 10 + 11 · (3 + 11 · 10) = 1253
5. (a2 a1 a0 )G = (a0 · 1 + a1 · G + a2 · G2 )10
6. (an an−1 . . . a1 a0 )G = (a0 · 1 + a1 · G + . . . an−1 · Gn−1 + an · Gn )10
7. M M M CCXXIII
8. Je kunt de regels in verschillende volgorden toepassen, een voorbeelduitwerking is:
77 + 588 =
=
=
=
=
=
=
=
=
=
7 + 10 · 7 + 8 + 10 · (8 + 10 · 5)
7 + 8 + 10 · 7 + 10 · (8 + 10 · 5)
7 + 8 + 10 · (7 + 8 + 10 · 5)
15 + 10 · (15 + 10 · 5)
1 · 10 + 5 + 10 · (1 · 10 + 5 + 10 · 5)
5 + 1 · 10 + 10 · (5 + 1 · 10 + 10 · 5)
5 + 10 · 1 + 10 · (5 + 10 · 1 + 10 · 5)
5 + 10 · (1 + 5 + 10 · (1 + 5))
5 + 10 · (6 + 10 · 6)
665
9. 11103 en 63211
10. 2223 = 2610 , 1113 = 1310 , 11103 = 3910
5X711 = 72210 , 3611 = 3910 , 63211 = 76110
11. 112213 , 21013 en 423X11
12. 2003 , 17211 en 111113
13. 143305
14. X0511
15. 6679
16. 2020213
12
(+ commutatief)
(· distribueert over +)
(optellen van getallen kleiner dan 10)
(delingsalgoritme)
(+ commutatief)
(· commutatief)
(· distribueert over +)
(optellen van getallen kleiner dan 10)
17. 0, 1, 10, 11, 100, 101, 110, 111, 1000, 1001, 1010, 1011, 1100, 1101, 1110, 1111, 10000,
10001, 10010, 10011
18. (an an−1 . . . a1 a0 )2 = (a0 · 1 + a1 · 2 + . . . an−1 · 2n−1 + an · 2n )10
19. 510 , 5310 en 1210
20.
n = q0 · 2 + r 0
q 0 = q1 · 2 + r 1
·
·
·
qk−1 = 0 · 2 + rk
r0 is het meest rechtse cijfer
r1 is het tweede cijfer
rk is het meeste linkse cijfer.
21. 1112 , 110012 , 100000002 en 110010002
22. 10000012 en 100012
23. 1101012 = 5310 , 11002 = 1210 , 10000012 = 6510
11002 = 1210 , 1012 = 510 , 100012 = 1710
24. 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F, 10, 11, 12, 13
25. 3809910 en 6416
26. 10011010001110112 en 5916
27. Bekijk bijvoorbeeld het hexadecimale getal 94D16 , dan geldt:
94D16 = 9 · 162 + 4 · 16 + 14
= (1 · 23 + 0 · 22 + 0 · 21 + 1) · (24 )2 + (0 · 23 + 1 · 22 + 0 · 21 + 0) · 24 +
(1 · 23 + 1 · 22 + 1 · 21 + 0)
= 1 · 211 + 0 · 210 + 0 · 29 + 1 · 28 + 0 · 27 + 1 · 26 + 0 · 25 + 0 · 24 + 1 · 23 +
1 · 22 + 1 · 21 + 0
waarbij we aan de rechterkant van het =-teken in het decimale stelsel rekenen. Dit
voorbeeld illustreert hoe je in het algemeen van hexadecimaal naar binair kunt omrekenen door elk cijfer in de hexadecimale cijfer te vervangen door het corresponderende blok van vier binaire cijfers.
Je kunt rechtstreeks van binaire naar hexadecimale notatie door het binair genoteerde
getal van rechts naar links te verdelen in blokken van vier cijfers en vervolgens elk
blok om te rekenen naar een hexadecimaal cijfer.
28. Mai Gehrke: 0243653220
Dion Coumans: 0243652872
29.
i. 256 · 256 · 256 = 224
ii. Bijvoorbeeld: rood FF0000, paars FF00FF, zwart 000000, grijs 7F7F7F
13
iii. Bijvoorbeeld: 00FFFF, FF00FF en FFFF00
30. 31. Stel dat het rijtje cijfers a1 a2 . . . an een geldige streepjescode is. Bereken: drie keer
de som van de cijfers op de even posities plus de som van de cijfers op de oneven posities. De uitkomst hiervan noemen we de controlewaarde van a1 a2 . . . an . Aangezien
a1 a2 . . . an een geldige streepjescode is, is deze controlewaarde deelbaar door 10. Als
we één van de cijfers in het rijtje vervangen door een ander cijfer, is er een aantal
mogelijkheden voor de nieuwe controlewaarde: De nieuwe controlewaarde is de oude
controlewaarde plus of min een getal tussen 1 en 9 (er is een cijfer op een oneven positie veranderd) of de nieuwe controlewaarde is de oude controlewaarde plus of min een
drie maal een getal tussen 1 en 9 (er is een cijfer op een even positie veranderd). In
alle gevallen is de nieuwe controlewaarde niet deelbaar door tien, doordat de getallen
tussen 1 en 9 niet deelbaar zijn door tien en ook drie maal een getal tussen 1 en 9
niet deelbaar is door tien. Dus het nieuwe rijtje is geen geldige streepjescode.
32. Als we beginnen met een twaalfcijferige code a1 a2 . . . a12 , dan kunnen we die als volgt
aanvullen tot een geldige streepjescode: Bereken 3 · (a2 + a4 + a6 + a8 + a10 + a12 ) +
a1 +a3 +a5 +a7 +a9 +a11 en noem de uitkomst x. Er bestaat een getal y tussen 0 en 9
zodat x + y deelbaar is door tien. Het rijtje a1 a2 . . . a12 y is een geldige streepjescode.
33. Bijvoorbeeld 2770000000000 en 7270000000000 zijn beide geldige streepjescodes. In
het algemeen geldt: Als het verschil tussen de twee naast elkaar gelegen cijfers 5 is,
dan levert het verwisselen van de twee cijfers weer een geldige streepjescode.
34. Nee, het rijtje 000000006 is bijvoorbeeld niet aan te vullen tot een geldige ISBN code.
35. Stel dat a1 . . . a10 een geldige ISBN-code is. Bereken 10·a1 +9·a2 +. . .+1·a1 en noem
dit de controlewaarde van a1 . . . a10 . Vervangen we één cijfer door een ander cijfer en
berekenen we de nieuwe controlewaarde, dan is dit de oude controlewaarde plus of
min (plaats van de verandering)·(verschil tussen oude en nieuwe waarde). De plaats
van de verandering is een getal tussen 1 en 10 en het verschil is een getal tussen 1 en
9. In alle gevallen is de nieuwe controlewaarde niet deelbaar door elf.
36. Bij het verwisselen van twee naast elkaar gelegen cijfers is het verschil tussen de oude
en de nieuwe controlewaarde het verschil tussen de twee cijfers. Dit verschil is een
getal tussen 1 en 9 (als de twee cijfers niet hetzelfde zijn). Als de oorspronkelijke
controlewaarde deelbaar is door elf, dan is de nieuwe controlewaarde niet deelbaar
door elf.
14
Download