Medium
Given an integer array nums and an integer k, return the number of subarrays of nums where the greatest common divisor of the subarray’s elements is k.
A subarray is a contiguous non-empty sequence of elements within an array.
The greatest common divisor of an array is the largest integer that evenly divides all the array elements.
Example 1:
Input: nums = [9,3,1,2,6,3], k = 3
Output: 4
Explanation: The subarrays of nums where 3 is the greatest common divisor of all the subarray’s elements are:
[9,3,1,2,6,3]
[9,3,1,2,6,3]
[9,3,1,2,6,3]
[9,3,1,2,6,3]
Example 2:
Input: nums = [4], k = 7
Output: 0
Explanation: There are no subarrays of nums where 7 is the greatest common divisor of all the subarray’s elements.
Constraints:
1 <= nums.length <= 10001 <= nums[i], k <= 109public class Solution {
    private int sol(int a, int b) {
        if (b == 0) {
            return a;
        }
        return sol(b, a % b);
    }
    public int subarrayGCD(int[] nums, int k) {
        int n = nums.length;
        int cnt = 0;
        for (int i = 0; i < n; i++) {
            int gcd = 0;
            for (int j = i; j < n; j++) {
                gcd = sol(gcd, nums[j]);
                if (gcd == k) {
                    cnt++;
                }
                if (gcd < k) {
                    break;
                }
            }
        }
        return cnt;
    }
}