Plot twist, neither cared about the table number

One went to the first table produced, the other to the first table placed

DROP TABLE 01;

Dangit Bobby!

they were never meant to be together, they would confuse the hell out of each other. Imagine they have two kids and she says pick kid[1] from the school, then what?

1st table is not equal to table 01 because there no 0st table

I work with juniper switches 0 is my 1

Fuck juniper fr though

@ikidd@lemmy.world
link
fedilink
English
010h

Nonbinary

Anna
link
fedilink
24
edit-2
3h

Hey, if she thinks 1 is 1st index then you dogged dodged a bullet and deserve better.

Happy now all you English majors.

MobileDecay
link
fedilink
17h

🐕🐕🐕

Bob
link
fedilink
3014h

you dogged a bullet

😳

Isn’t the guy at the zeroith table?

@TwilightKiddy@programming.dev
link
fedilink
English
27
edit-2
19h

There is no such thing as “zeroith”. Does not matter which numbers you slap on the tables, the one with the lowest number will always be the first. The word “first” has nothing to do with indices, it’s just an antonym for “last”.

@0ops@lemm.ee
link
fedilink
516h

I kind of brought this up in another comment, that “first” and “1st” aren’t really the same thing. Which is confusing when you extend that to fourth/4th five/5th. I don’t generally see someone write “zeroith”, but I’ll see “0th”.

And here I thought people write “1st” because they are lazy and want to press 3 keys instead of 5.

That’s a problem when you get to the fourth.

lad
link
fedilink
English
3
edit-2
9h

There’s no such thing as “zeroith” because it’s called “zeroth — being numbered zero in a series”

This works for building storeys, this would work equally well for tables. The only reason this is not used often is because the series are rarely zero-based in anything that doesn’t also want to equate index and offset.

You’re right that first may be read as “opposite of last”, that would add to the confusion, but that’s just natural language not being precise enough.

Edit: spelling

Edit2: also, if you extend that logic, when you’re presented with an ordinal number, you would need to first check all the options, sort them, and then apply the position you’re asked, that’s not really how people would expect ordinal number to be treated, not me, at the very least

Yes, and if he texted “Hey, I’m at the zeroith table” and the woman replied with the sibling comment then you know to run far and run fast.

Wouldn’t it be nice if documentation used the words index and offset consistently?

Zagorath
link
fedilink
218h

Aren’t those two the same thing? At least in C-style arrays, which might not be how they’re handled under the hood, but is at least how most languages present it to the programmer.

Yes they are presented in the programmer wrong. The first thing in memory should have offset 0 and index 1

in my understanding offset is technically the “relative index”, or how much you have to go further

@dohpaz42@lemmy.world
link
fedilink
English
918h

The problem is that they both are contextual and can mean any position in a list/array. The starting index or starting offset is generally zero, but could be one, depending on the language used.

i wonder why people haven’t made a language that starts indexing at 2 yet. maybe some day

Maybe this could be a feature in brainfuck or COBOL.

god i hope so

She was a lua girl, he was every other programming language guy. It was not ment to happen.

Hey, don’t forget the Matlab people

And R!

IS THIS Love Advice From the Great Duke of Hell??

(it’s a webcomic, I loved the story)

Bullshit.

Every programmer knows that 'A' in ['A', 'B', 'C', 'D'] would be the 0th item; the first item is 'B'

I’ve been a software engineer for almost 20 years now. ‘A’, at index 0*, is the first thing in the array.

* well, unless you’re using some language that actually is not zero-indexed. I think LUA is one?

That’s because you use English, a language where ordinals traditionally begin at one.

So, based on

Every programmer knows that ‘A’ in [‘A’, ‘B’, ‘C’, ‘D’] would be the 0th item; the first item is ‘B’

You’re saying I can’t be a programmer because I speak English?

No, what I said is true if you use zero-based numbering. But when communicating with others in English, the label “first” refers to the element with the smallest index. In zero-based numbering, the label “zeroth” refers to the element with the lowest index. It’s just not the default in English, but you can definitely use zero-based numbering in English if you’re willing to edit the configuration files.

That would be wrong in every technical sense. You’re saying that .first() would skip the 0th item.

First = leftmost.

@NateNate60@lemmy.world
link
fedilink
2
edit-2
11h

That’s because the word “first” in first() uses one-based indexing. In true programmer fashion it would have been called zeroth() but that is wholly unintuitive to most humans.

I maintain that the element with the lowest index is called the “zeroth” element in zero-based indexing and “first” in one-based indexing. The element with index N is the Nth element.

Melmi
link
fedilink
English
010h

Indexes start from zero because they’re memory offsets, but array[0] is still the first element because it’s an ordinal number, not an offset. It’s literally counting each element of the array. It lines up with the cardinality—you wouldn’t say ['A', 'B', 'C'] has two elements, despite array[2] being the last element.

Zero-based indexing redefines the meaning of the labels “first”, “second”, “third”, and so on. It adds a new label, “zeroth”, which has the same ordinal value as “first” in one-based indexing. The word “first” does not mean “the element with the lowest index” in zero-based indexing.

If you are using a zero-based numbering system, you would absolutely say that array[2] is the final element in the array, that element having the ordinal label “second”, and yet the length of the array is 3 (cardinal). There is no fundamental connection between the ordinal labels “zeroth”, “first”, “second”, and “third” and the cardinal numbers 0, 1, 2, and 3. The similarities are purely an artefact of human language, which is arbitrary anyway. You can make an equally mathematically valid ordinal numbering system that assigns “third” to the element with the smallest index, “fourth” to the next-smallest, and so on. That ordinal numbering system is mathematically coherent and valid, but you’re just causing trouble for yourself when it comes time to convert those ordinals (such as array indexes) into cardinals (such as memory locations or lengths of fencing to buy).

You can make an argument for why one-based numbering is more convenient and easier to use, but you cannot use the notion that zero-based numbering doesn’t make sense given the assumed context of one-based numbering as an argument for why zero-based numbering is invalid.

I encourage you read up what is meant by “zero based numbering” because you and everyone else who has replied to me has tried to use “but that’s not how it works in one-based numbering” as an explanation for why I’m wrong. This is as nonsensical of an argument as trying to say i (the imaginary unit) is not a number because it’s not on the number line. It’s only not a number in the domain of the real numbers. Similarly, zero-based numbering is only nonsensical in the context of one-based indexing.

It does not matter why indexes start from zero. The memory offset argument is only salient if you are using it as an argument for why computers should use zero-based numbering.

Melmi
link
fedilink
English
1
edit-2
9h

Yeah, fair enough. To my mind I guess I don’t think of array indexes as an example of actual zero based numbering, simply a quirk of how pointers work. I don’t see why one starting from zero has anything to do with the other starting from zero. They’re separate things in my head. Interestingly, the article you linked does mention this argument:

Referencing memory by an address and an offset is represented directly in computer hardware on virtually all computer architectures, so this design detail in C makes compilation easier, at the cost of some human factors. In this context using “zeroth” as an ordinal is not strictly correct, but a widespread habit in this profession.

That said, I suppose I still use normal one-based numbering because that’s how I’m used to everything else working.

No, there is simply no such thing as “zeroth”, that’s not how ordinal numbers work. If I have the following numbered list:

  1. Foo

  2. Bar

  3. Baz

The first item is “Foo” which is indexed 5. It is not the fifth item, because the item indexed 5 comes first in the list, so the item indexed 5 is the first item. Ordinal numbers don’t refer to index, they refer to order.

Okay, I will admit, you got me there. I did confuse indexing with numbering. From now on I will use the term “numbering” instead.

It is entirely how ordinal numbers work in zero-based numbering. There is no “right way” for ordinal numbers to work. You can create a valid ordinal numbering system starting from any integer, or just some other ordered list. You cannot assume one-based numbering is “correct” and use it as an argument against numbering beginning from any other number.

I encourage you read up what is meant by “zero based numbering” because you and everyone else who has replied to me has tried to use “but that’s not how it works in one-based numbering” as an explanation for why I’m wrong. This is as nonsensical of an argument as trying to say i (the imaginary unit) is not a number because it’s not on the number line. It’s only not a number in the domain of the real numbers. Similarly, zero-based numbering is only nonsensical in the context of one-based indexing.

Zero-based numbering would number “foo” as the zeroth element, “bar” as the first element, and “baz” as the second element. “zeroth”, “first”, and “second” are labels representing ordinals. Your list has a length of 3 (which is a cardinal quantity unrelated to ordinals).

Although, I would like to point out, it is perfectly valid to construct an ordinal labelling system that assigns “fifth” to the element with the lowest index, “sixth” to the next, and so on. That system is mathematically coherent but it is just troublesome to when it comes time to convert ordinal numbers (such as the index of the last fence-post) to cardinal numbers (such as the length of fence to buy).

But this is now getting into the weeds of pure mathematics and most people here are engineers.

@dave@feddit.uk
link
fedilink
English
211h

Most humans wouldd never write the word first followed by (). It absolutely should have been zeroth(), and would not cause any confusion amongst anyone who needed to write it.

It absolutely should not have been named zeroth() because the reasoning for that is purely pedantic and ignores WHY arrays are 0 indexed. It’s not like the people in the early days of writing programming languages were saying “the zeroth item in the array” - they would refer to it using human language because they are humans, not machines. Arrays are 0 indexed because it’s more efficient for address location. To get the location in memory of an array item, it’s startingAddress + (objectSize * index). If they were 1 indexed, the machine would have to reverse the offset.
Function/Method names, on the other hand, should be written so as to make the most sense to the humans reading and writing the code, because the humans are the only ones that care what the name is. When you have an array or list, it’s intuitive to think “I want the first thing in the array” or “I want the last thing in the array),” so it makes sense to use first and last. That also makes them intuitive counterparts (what would be the intuitive counterpart to “zeroth”?).

@dave@feddit.uk
link
fedilink
English
210h

Function/Method names, on the other hand, should be written so as to make the most sense to the humans reading and writing the code

Of course—that’s why we have such classics as stristr(), strpbrk(), and stripos(). Pretty obvious what the differences are there.

But to your point, the ‘intuitive’ counterpart to ‘zeroth’ is the item with index zero. What we have is a mishmash of accurate and colloquial terms for the same thing.

My argument is purely pedantic. Pedantry is the lifeblood of programmer “humour”.

I’m not arguing that we should adopt zero-based numberingin real-life human applications. I am arguing that in zero-based numbering, the label “zeroth” refers to the same ordinal as “first” in one-based numbering. I am poking fun at the conversion between human one-based numbering and computers’ zero-based numbering. That is why I am saying it should be called zeroth(); because human language should adapt to match the zero-based numbering their tools use. Whether I actually mean what I say—well, I leave that up to you.

It does not matter why indexes start from zero in computing. The memory offset argument is only salient if you are using it as an argument for why computers should use zero-based numbering. It is not an argument against the properties of zero-based numbering itself.

1st would be ‘B’, first is ‘A’

@tunetardis@lemmy.ca
link
fedilink
English
418h

This could be why Obiwan wound up a hermit? (Programmers of my generation at least talk about “Obiwan errors” because his name sounds like “off-by-one”.)

I still mess this up for lists in Python…

Don’t wanna state the obvious, but it looks like they still ended up staring at each other for the rest of the evening.

They have shown that they still love each other, so hope they can work with their one irreconcilable difference.

👍Maximum Derek👍
link
fedilink
English
3519h

I love the idea that they’re at two adjacent tables, each one staring at the other wondering why they hate them.

They hate each other because they are intolerant to one another’s index choices

Create a post

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

  • Posts must be relevant to programming, programmers, or computer science.
  • No NSFW content.
  • Jokes must be in good taste. No hate speech, bigotry, etc.
  • 1 user online
  • 120 users / day
  • 257 users / week
  • 744 users / month
  • 3.72K users / 6 months
  • 1 subscriber
  • 1.48K Posts
  • 32.7K Comments
  • Modlog