Description
data:image/s3,"s3://crabby-images/d0dca/d0dca95e1e213688cc40268e6d0035616be7f543" alt=""
data:image/s3,"s3://crabby-images/e6de3/e6de3b13368b4de67966bb07fe8d0151f15c4ad1" alt=""
Submission
class Solution { public: int lastRemaining(int n) { bool isFromLeft = true; // is from left int left = 1; int remain = n; int step = 1; while(remain > 1) { if(isFromLeft || remain % 2 == 1) { left += step; } step = step << 1; remain = remain >> 1; isFromLeft = !isFromLeft; } return left; } };
data:image/s3,"s3://crabby-images/f8563/f85632cc3a2eb8b7c6012341056a8f3aea0ab0b6" alt=""