Kth Smallest Subarray Sum
找第k小的subarray sum.
这题吧..如果不卡时间, 应该不难, 但是这题用treeset过不了, 所以只能用binary search做, 已知subarray sum可以用pre sum求, 并且是递增的 (nums[i] >= 1) 所以这题可以用binary search找一个mid最小值下, 第k的值.
class Solution {
public int kthSmallestSubarraySum(int[] nums, int k) {
int l = 0;
int r = Integer.MAX_VALUE;
while(l < r)
{
int m = (l + r) / 2;
int f = check(nums, m);
if(f < k)
l = m + 1;
else
r = m;
}
return l;
}
public int check(int[] nums, int m){
int sum = 0;
int i = 0;
int j = 0;
int res = 0;
while(i < nums.length){
if(sum + nums[i] <= m){
sum += nums[i];
i++;
res += i - j;
}
else
{
sum -= nums[j];
j++;
}
}
return res;
}
}
class Solution {
public int kthSmallestSubarraySum(int[] nums, int k) {
int n = nums.length;
int[] pre = new int[n + 1];
for(int i = 1 ; i <= n; i++) {
pre[i] = pre[i - 1] + nums[i - 1];
}
LinkedList<Integer> list = new LinkedList<>();
for(int i = 0; i <= n; i++){
for(int j = i + 1; j <= n; j++){
list.add(pre[j] - pre[i]);
}
}
Collections.sort(list);
System.out.println(list);
while(--k != 0){
list.removeFirst();
}
return list.getFirst();
}
}