1

当我尝试编译这个二进制搜索程序时,我收到一条消息说我有未经检查和不安全的操作。我查看了 stackoverflow 上的其他帖子,但我不知道如何修复我的代码。谢谢!

public binarySearch()
{
    ArrayList<Integer> list = new ArrayList<Integer>();
    for (int i=0;i<10;i++)
    {
        int rand = (int)(Math.random()*10);
        list.add(rand);
        System.out.print(list.get(i)+"\t");
        if ((i+1)%10==0) System.out.println();
    }   
    System.out.println("\n"+search(sort(list),0));
}

public ArrayList sort(ArrayList<Integer> listNum)
{
    for (int i=0;i<listNum.size()-1;i++)
    {
        int min=10000;
        int index=0;
        for (int j=i;j<listNum.size();j++)
            if (listNum.get(j)<min) 
            {
                min=listNum.get(j);
                index=j;
            }
        int temp = listNum.get(i);
        listNum.set(i,listNum.get(index));
        listNum.set(index,temp);
    }
    return listNum;
}   

public boolean search(ArrayList<Integer> listNum, int num)
{
    //need to sort list
    int low = 0;
    int high = listNum.size()-1;
    while (low<=high)
    {
        int mid = (low+high)/2;
        int midValue = listNum.get(mid);
        if (num<midValue)
            high = mid-1;
        if (num>midValue)
            low = mid+1;
        if (num==midValue)
            return true;
    }
    return false;
}

public static void main (String args[])
{
    binarySearch app = new binarySearch();
}
4

2 回答 2

3

方法返回应该是 public ArrayList<Integer> sort(ArrayList<Integer> listNum)

于 2013-03-02T17:25:32.827 回答
1

您的 sort 方法返回Raw 类型,因此是编译器警告。使您的排序方法返回参数化类型的 ArrayList。

public ArrayList<Integer> sort(ArrayList<Integer> listNum)

有用的帖子:

于 2013-03-02T17:26:02.627 回答