• sus@programming.dev
      link
      fedilink
      arrow-up
      4
      ·
      13 hours ago

      We can avoid expensive branches (gasp) by using some bitwise arithmetic to achieve the so-called “absolute value”, an advanced hacker technique I learnt at Blizzard. Also unlike c, c# is not enlightened enough to understand that my code is perfect so it complains about “not all code paths returning a value”.

      private bool IsEven(int number)
      {
          number *= 1 - 2*(int)(((uint)number & 2147483648) >> 31);
          if (number > 1) return IsEven(number - 2);
          if (number == 0) return true;
          if (number == 1) return false;
          throw new Exception();
      }