hairinmybellybutt@lemmy.world to Programmer Humor@lemmy.mlEnglish · 10 months agocountinglemmy.worldimagemessage-square26fedilinkarrow-up1195arrow-down110
arrow-up1185arrow-down1imagecountinglemmy.worldhairinmybellybutt@lemmy.world to Programmer Humor@lemmy.mlEnglish · 10 months agomessage-square26fedilink
minus-squareDestide@feddit.uklinkfedilinkEnglisharrow-up0·10 months agoHaaaaaang on is that why we start on 0…
minus-squaremacniel@feddit.delinkfedilinkarrow-up2·10 months agoNo. We count start at zero because the array already starts with an element of a specific size. Starting at 1 would always skip that initial element.
minus-squareCanadaPlus@futurology.todaylinkfedilinkEnglisharrow-up4·edit-210 months agoYou could have “empty arrays” in a language if you wanted. The real reason is that you start with an offset of zero as you read an array from memory at hardware level, and so this way address is just “start address + element size * element number”.
minus-squareBorgDrone@lemmy.onelinkfedilinkarrow-up2·edit-210 months agoNo, we start counting at one. We start indexing at zero. An array with one element has an element count of 1, and that element would be at index 0.
minus-squareLaggyKar@programming.devlinkfedilinkarrow-up2·10 months agoThis is how we end up with off-by-one errors
Haaaaaang on is that why we start on 0…
No. We count start at zero because the array already starts with an element of a specific size. Starting at 1 would always skip that initial element.
You could have “empty arrays” in a language if you wanted. The real reason is that you start with an offset of zero as you read an array from memory at hardware level, and so this way address is just “start address + element size * element number”.
No, we start counting at one. We start indexing at zero.
An array with one element has an element count of 1, and that element would be at index 0.
This is how we end up with off-by-one errors