如何使用冒泡排序找到最长的船(长度)?

时间:2015-03-27 15:46:46

标签: java android list sorting

我正在处理一个处理单例类的项目,该类是一个船只列表。我正在开展一项活动,展示最长的船。我想尝试使用冒泡排序按其最长的船对列表进行排序。该应用程序运行,但当我按下按钮显示最长的船时,它停止工作。有谁可以帮助我?

public void showLongBoat(View view)
{
    //Declare references
    BoatList boat_list;
    TextView tv;
    int i;
    int x = 0;
    boolean found;
    int num_items;
    int visit = 0;
    boolean exchange_value;
    int last_item;
    int temp;
    int a = 0;
    int b;

    //Set references. Access the list.
    boat_list = BoatList.getInstance();

    tv = (TextView) findViewById(R.id.text_main);

    //Get the number of items in the list
    num_items = boat_list.size();

    //Find the longest boat
    i = 0;
    found = false;

    while(!found && (i < boat_list.size()))
    {
        //If num_item is 0 or 1, then do not sort. Otherwise, do sorting
        if(num_items > 1)
        {
            //Set the number of values to visit on the first pass
            visit = num_items - 1;
        }

        do
        {
            //No exchange or swapping of item was made, so set the    exchange to false
            exchange_value = false;

            //Set the index for the last item to visit
            last_item = visit - 1;

            for(x = 0; x <= last_item; x++)
            {
                if(boat_list.get(x).getLength() > boat_list.get(x).getLength() + 1)
                {
                    //Swap the item
                    temp = a;
                    a = boat_list.get(x).getLength() + 1;
                    b = temp;

                    exchange_value = true;
                }
            }

            visit--;
        }while(exchange_value && (visit > 0)); //end sort
    }

    if(found)
    {
        boat_list.get(x).getLength();
        tv.append("Longest Boat is: ");
    }
    else
    {
        Toast.makeText(ShowLongBoatActivity.this, "Error: Cannot find the longest boat successfully!",
                Toast.LENGTH_SHORT).show();
    }

} //end of showLongBoat

1 个答案:

答案 0 :(得分:0)

这是一个无限循环,因为您不会修改foundi或循环内的列表大小:

while(!found && (i < boat_list.size()))

您的代码中不需要3个循环。如果你只想要最长的船,可以在船上重复一次,并尽可能地使用它。如果要使用冒泡排序算法进行排序,最大元素将在排序后结束。