这是我的代码,它可以找到1-7个最小整数,但可以找到8和9。当我在数组中找到8个最小整数时,它返回null。谁能帮我解决问题所在?我在这里使用quicksort。
非常感谢!

更新:我已经解决了问题,这是主要功能中的数组。在更改为以下外观后,

int[] arr = {2, 3, 1, 7, 5, 6, 20, 8, 4, 9};


if(front>=end) return input;

现在可以使用!
import java.util.Arrays;
import java.io.*;

class quicksort{
public static void main(String[] args){
    int[] arr = new int[9];
    arr[0] = 7;
    arr[1] = 2;
    arr[2] = 4;
    arr[3] = 8;
    arr[4] = 3;
    arr[5] = 5;
    arr[6] = 1;
    arr[7] = 0;
    arr[8] = 10;

    System.out.println((Arrays.toString(findKSamllest(arr,8))));
}
public static int partition(int[] input, int front, int end){
    int pivot = input[front];
    while(front < end){
        while(input[front]<pivot)
            front++;
        while(input[end]>pivot)
            end--;
        swap(input,front,end);
    }
    return front;
}
public static void swap(int[] input, int s, int l){
    int temp = input[s];
    input[s] = input[l];
    input[l] = temp;
}

public static int[] findK(int[] input, int front, int end, int k){
    if(front>=end) return null;
    int pivot = partition(input,front,end);
    //System.out.println(pivot);
    if(k==pivot){
        return Arrays.copyOfRange(input,0,pivot);
    }
    else {
        if(k<pivot)
            return findK(input,front,pivot,k);
        return findK(input,pivot+1,end,k);
    }
}
public static int[] findKSamllest(int[] input, int k){
    return findK(input, 0, input.length-1, k);
}

}

最佳答案

更改

if(front >= end) return null;


if(front > end) return null;

关于java - 找出数组中的k个最小整数,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/26892835/

10-10 04:19