this post was submitted on 07 Dec 2023
2 points (100.0% liked)

Programming Horror

1849 readers
1 users here now

Welcome to Programming Horror!

This is a place to share strange or terrible code you come across.

For more general memes about programming there's also Programmer Humor.

Looking for mods. If youre interested in moderating the community feel free to dm @Ategon@programming.dev

Rules

Credits

founded 1 year ago
MODERATORS
 
all 26 comments
sorted by: hot top controversial new old
[–] olafurp@lemmy.world 2 points 10 months ago (1 children)

Of course there's an easier way. Just integrate the state of the art API dedicated for this exact problem. https://isevenapi.xyz/

[–] misophist@lemmy.world 2 points 10 months ago

This is confusing. I'm already using the iSeven API to determine if a number is 7. I'm getting a namespace collision error when I try to load this new API. Bug report filed.

[–] Thyrian@ttrpg.network 2 points 10 months ago (1 children)

You could do this in one line...

By removing all the linebreaks.

[–] aodhsishaj@lemmy.world 1 points 10 months ago (2 children)
[–] dylanTheDeveloper@lemmy.world 1 points 10 months ago

I'm more of a Gemini myself

[–] whyNotSquirrel@sh.itjust.works 1 points 10 months ago

print(theJoke % you);

wooosh

[–] recursive_recursion@programming.dev 1 points 10 months ago* (last edited 10 months ago) (2 children)

modulo

pseudocode:

if number % 2 == 0
  return "number is even" (is_num_even = 1 or true)
else
  return "number is odd" (is_num_even = 0 or false)

plus you'd want an input validation beforehand

[–] mac@programming.dev 1 points 10 months ago* (last edited 10 months ago) (1 children)

who needs modulo when you can get less characters out of

while (number > 1) {
  number -= 2;
}
return number;

very efficient

edit: or theres the trusty iseven api

[–] nullPointer@programming.dev 1 points 10 months ago (1 children)

here is somewhat less:

return (number % 2) == 0;

[–] pivot_root@lemmy.world 1 points 10 months ago

return !(number & 1);

[–] Vex_Detrause@lemmy.ca 0 points 10 months ago (1 children)
#You are an input. You have value! You matter!
if number % 2 == 0
  return "number is even" (is_num_even = 1 or true)
else
  return "number is odd" (is_num_even = 0 or false)

Am I doing it right? /S.

[–] PoolloverNathan@programming.dev 1 points 10 months ago

Don't put nbsps in code blocks, they show up literally.

[–] Anticorp@lemmy.world 1 points 10 months ago (2 children)

Back when I was learning programming a lot of lessons would make you do something like this, and then show you the real way to do it in the next lesson. My reaction was always "why didn't you lead with this?".

You must see the pain before you confront it.

[–] Coreidan@lemmy.world 1 points 10 months ago

Because the point of the lesson is to demonstrate that you can solve the same problem multiple ways where some paths are more efficient than others.

Bad programmers are the ones that find the first solution and implement it no matter how inefficient it is.

Good programmers spend time on figuring out the solution with the least amount broken or inefficient code. You don’t learn this by jumping straight to the best answer every time.

[–] neidu@feddit.nl 1 points 10 months ago* (last edited 10 months ago) (1 children)

My solution in perl back in the day when I was a teenage hobbyist who didn't know about the modulus operator: Divide by 2 and use regex to check for a decimal point.

if ($num / 2 =~ /\./) { return "odd" }
else { return "even" }

[–] lysdexic@programming.dev 1 points 10 months ago (1 children)

Divide by 2 and check for a decimal point.

I mean, it ain't wrong.

[–] Chobbes@lemmy.world 1 points 10 months ago (1 children)

You know, I was going to let this slide under the notion that we're just ignoring the limited precision of floating point numbers... But then I thought about it and it's probably not right even if you were computing with real numbers! The decimal representation of real numbers isn't unique, so this could tell me that "2 = 1.9999..." is odd. Maybe your string coercion is guaranteed to return the finite decimal representation, but I think that would be undecidable.

[–] backgroundcow@lemmy.world 1 points 10 months ago (1 children)

Ackchyually-- IEEE 754 guarantees any integer with absolute value less than 2^24 to be exactly representable as a single precision float. So, the "divide by 2, check for decimals" should be safe as long as the origin of the number being checked is somewhat reasonable.

[–] Chobbes@lemmy.world 1 points 10 months ago

Of course, but it's somewhat nasty when all of a sudden is_even doesn't do what you expect :).

[–] Thyrian@ttrpg.network 0 points 10 months ago (1 children)

This could be optimized by using a recursive function.

[–] neeeeDanke@feddit.de 0 points 10 months ago

This could be made more servicavle by using a switch case

[–] SpeakinTelnet@programming.dev 0 points 10 months ago* (last edited 10 months ago) (1 children)
def is_even(n):
    match n:
        case 1:
            return False
        case 0:
            return True
        # fix No1
        case n < 0:
            return is_even(-1*n)
        case _:
            return is_even(n-2)
[–] sloppy_diffuser@sh.itjust.works 0 points 10 months ago (1 children)

Python added match/case?! Bunch of mypy issues have been closed too. Maybe its time to dust off some old projects.

[–] SpeakinTelnet@programming.dev 1 points 10 months ago

It was added in 3.10 and is surprisingly complete. The tutorial pep is a good starting point to see what it can accomplish