Given an integer num, find the closest two integers in absolute difference whose product equals num + 1 or num + 2.
Return the two integers in any order.
Example 1:
Input: num = 8Output: [3,3]Explanation: For num + 1 = 9, the closest divisors are 3 & 3, for num + 2 = 10, the closest divisors are 2 & 5, hence 3 & 3 is chosen.
Example 2:
Input: num = 123Output: [5,25]
Example 3:
Input: num = 999Output: [40,25]
Constraints:
1 <= num <= 10^9
题意
给定一个数num,求一组差最小的两个数,且这两个数之积等于num+1或num+2。
思路
从开根处往前搜索,最后比较得到的两组值。
代码实现
class Solution {public int[] closestDivisors(int num) {int[] p1 = solve(num + 1);int[] p2 = solve(num + 2);return p1[1] - p1[0] < p2[1] - p2[0] ? p1 : p2;}private int[] solve(int num) {int[] pair = new int[2];int mid = (int) Math.sqrt(num);for (int i = mid; i >= 1; i--) {if (num % i == 0) {pair[0] = i;pair[1] = num / i;break;}}return pair;}}
