You have M square tiles of size 1×1 and N square tiles of size 2×2. Your task is to create the largest possible square using these tiles. Tiles may not overlap, and the resulting square should be filled (it should not contain empty spaces).
Write a function:
class Solution { public int solution(int M, int N); }
that, given two integers M and N, returns the length of the side of the largest square you can create. If no square can be created, your function should return 0.
Examples:
- Given M = 8 and N = 0, your function should return 2. You can use four out of eight tiles to arrange them into a 2×2 square. There are not enough tiles to create a 3×3 square.
- Given M = 4 and N = 3, your function should return 4. You can obtain a 4×4 square by arranging four 1×1 tiles into a 2×2 square, and surrounding it by 2×2 tiles.
data:image/s3,"s3://crabby-images/32335/32335908d7e576cce92239f01b6ba87f35cb9355" alt=""
- Given M = 0 and N = 18, your function should return 8. You need to use sixteen 2×2 tiles to create the square. Note that not all the tiles are used.
- Given M = 13 and N = 3, your function should return 5. One of the possible arrangements is shown in the following image.
data:image/s3,"s3://crabby-images/77ed7/77ed75f0385820d4dfcb1d53d85d76fd6a30038d" alt=""
Constraints:
- M and N are integers within the range [0,1,000,000,000].
我们长期稳定承接各大科技公司如TikTok、Google、Amazon等的OA笔试代写服务,确保满分通过。如有需求,请随时联系我们。
We consistently provide professional online assessment services for major tech companies like TikTok, Google, and Amazon, guaranteeing perfect scores. Feel free to contact us if you're interested.
data:image/s3,"s3://crabby-images/4066e/4066e968cf80d908b7f8245e9b96d2617e914715" alt=""