https://learnprogramming.in.net/fenwick-tree-binary-indexed-tree-implementation-in-java/