this post was submitted on 21 Dec 2024
74 points (94.0% liked)

Fun Loops ▶️

336 readers
202 users here now

Posting interesting/cool/funny videos from Loops here

https://loops.video/

Thanks to @Bluefruit @lemmy.world for the icon and banner!

Discussion of and questions about Loops should go over in [email protected]

If the loop you're posting isn't original content uploaded by the creator, prefix the title with [R] for "reposted". For example, [R] Cute dog.

If you know the source for a loop marked [R], please comment with it!

Rules:

  1. Don't be a dick
  2. Don't make me add more rules

founded 1 month ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] -3 points 1 week ago (4 children)

I'm sorry, but even without knowing about the mod operator, this is inefficient and over engineered. Why have a loop at all?

fun isEven(n: Int){
    return n == abs(n)
}

no loop required...

having said that, I can totally see how that was missed in a high pressure interview. I hate interviews like that!

edit: Ha ha... isEven...not isPositive... I'm tired. ignore me!

[–] [email protected] 11 points 1 week ago* (last edited 1 week ago) (1 children)

Because the abs(3) == 3 is true and that isn't even.

An even number of flips would be true and an odd number of flips would be false which works out.

I was thinking a bitwise & or converting it to a string and testing if the right most character is 0, 2, 4, 6, 8 would be panic mode solutions too.

[–] [email protected] 2 points 1 week ago (1 children)

you might be able to do it with a bitwise op? My track record tonight is not great so I'm not going to comment. Have a look at @ImplyingImplactions comment for a loopless solution

[–] [email protected] 2 points 1 week ago

Bitwise and with 0x1. If result is 0, it's even. Least significant bit is always 1 for odd numbers.

[–] [email protected] 9 points 1 week ago (1 children)

Lol I think the interview pressure got to you.

[–] [email protected] 6 points 1 week ago

Ha ha ha, yup... whoops!

[–] [email protected] 8 points 1 week ago (1 children)

I'm not following.
n == abs(n) only tells you if it's positive.

[–] [email protected] 6 points 1 week ago (1 children)

yes, I'm being a dumb tonight. I'm completely wrong

[–] [email protected] 3 points 1 week ago

Haha, s'all good, yo.

[–] [email protected] 8 points 1 week ago (2 children)

That would be isPositive.

Without using the modulo operator you'd essentially have to reimplement it. Divide the number by 2 and round down. Multiply that by 2 and then subtract it from the original number.

isEven(10) results in 10-10==0 (true) whereas isEven(13) results in 13-12==0 (false).

function isEven(n){
  n = Math.abs(n)
  return (n - (Math.floor(n/2) * 2)) == 0
}
[–] [email protected] 5 points 1 week ago

Yep! I'm wrong. Pretty embarrassing!

That's a nice solution though! Gonna have to try and remember that one!

[–] dream_weasel 4 points 1 week ago* (last edited 1 week ago)

Minor simplification: this works even without taking absolute value first of you use fix instead of floor.

Edit: I don't know if fix is in the stock math library on second thought...