Ad
  • Custom User Avatar

    Yeah, but it was just a coincidence that I had just seen bitwise being explained to me on leetcode in their video solution for this problem.

    https://leetcode.com/explore/featured/card/the-leetcode-beginners-guide/692/challenge-problems/4425/

    I thought it was pretty cool and looked it up, then I seen it in your solution here on the same day

  • Custom User Avatar

    When writing real code, clarity is the most important rule in practice, beyond doing smart tricks. You do NOT need to use bitwise operations in non-bitwise-based logic. We only did it because we're used to code golfing.

  • Custom User Avatar

    I have just learned about bitwise operators today. I will, like you, start using them in practice.

  • Custom User Avatar
  • Custom User Avatar

    I think this is the most clever solution I've seen.

  • Custom User Avatar

    Thank you so much for your explanation and the function explaining it. I tested it and it worked with my assumptions in the way your functions explained. I shall look more into bitwise operations as well.

  • Custom User Avatar

    This kind of cheating is punishable, don't do this again.

  • Custom User Avatar
  • Custom User Avatar

    Yeah, this kata is cool and all but it even rejected my code just because it had a blank newline, like yeah wth

  • Custom User Avatar

    Most entertainig part was to write a script that generates the solution

  • Custom User Avatar

    May I quote myself from before?

    And you have to write the best random tests you can think of anyway.

    More is better. Of course better is also better.

    YES, you also have to write the best fixed tests you can think of.

  • Custom User Avatar

    I was just talking that if bug can happen, increasing number of same tests, with random data set and values in same domain doesn't actually help that much to catch it. It can help in some cases, but one needs to be lucky :) What can help for sure is to add more edge-cases covering for tests.

    So for example to catch bug with sum called w/o arguments we need to change tests so that they will call it w/o arguments :) The thing is that, again, we need to extend data domain, not it's quantity. Generating current random test-cases in for loop won't help to catch this at all.

  • Custom User Avatar

    I hear you.

    You do not rely on it only, but it does have its place.

    Eliminate all possible bugs with fixed tests, and someone will invent a new bug in a solution that passes your tests (or your kata task is probably really very limited and uninteresting).

    Mind you, if random testing (fuzz testing) exposes an edge condition you have no fixed test for (yet), you should definitely add a fixed test for it. But (1) that's often an iterative process and (2) you never know if you've covered all possible edge conditions.

    I just noticed that you don't test with sum() at all. sum() should be 0 I guess. You can define sum to always take at least one argument, but then somebody will filter out zeroes in an of course misguided attempt to make his calculation more efficient, and be left with zero arguments, some day. Should he blow up the planet because he just went out of spec?

    Really, I wish you good luck eliminating "things happening". Random testing won't eliminate it - but it will help reducing it. And I remain unconvinced you're going to fully eliminate it.

  • Custom User Avatar

    I just don't like relying on random in tests. Suffered from this a lot during E2E and integration testing, due to their nature. You're talking about thing called "fuzz testing" (https://en.wikipedia.org/wiki/Fuzzing), and still it's more about picking random data domain, than random data in just in bigger quantities. This kind of tests doesn't guarantee 100% coverage of control flow. In practice I've learned a lesson that if thing can happen, but the probability is extremely low - it will happen anyway, just give it a time. So it doesn't makes sense to lower this probability, you need to eliminate it.

  • Custom User Avatar

    Non-negative integers only is perfectly acceptable and indeed it allows users to focus on normal cases, which is generally a good thing.

    That still leaves open the possibility of solutions having bugs you're not going to find with limited testing. With random tests, there's always the chance of slipping through the cracks, but with enough of 'em, the possibility is smaller, going to zero. With fixed tests, it's an all-or-nothing proposition - it either finds the bug, or it doesn't. If you haven't foreseen a particular bug, maybe because of it being too subtle, or it depending on something you don't do in your reference solution but some user out there thought was a good idea at the time, it probably won't be caught. This puts an onus on the random tests as well, to generate as many different inputs as reasonably possible, to have the highest possible chance of finding bugs.

    Two recent examples of testing done not entirely good enough:

    • User had to sort a list of values according to some criteria. User solution was only tested with lists of values all different from each other (both in fixed and random tests). At least one solution returned not list.sort() but list.uniq().sort(), if you get my drift. This was not called for according to the description, but it was never caught.
    • Same kata: this very subtly buggy solution. With the specified input domain, it could not even be tested against! but the solution definitely is wonky.

    Does all of this mandate hundreds of random tests? No, but the chance of finding a bug increases (a little) with every random test. So, within reason, more is better. And you have to write the best random tests you can think of anyway.

  • Loading more items...