尝试运行鸡尾酒代码java [重复]时超出范围异常

问题描述 投票:0回答:1

我正在尝试制作鸡尾酒,但我在if (a[i] > a[i + 1])线上得到一个出界的例外,我不知道为什么。

这是完整的代码。对不起,如果这是完全错误的。

import java.util.Arrays;
import java.util.Scanner;

public class Cocktail 
{

public static void main(String[] args) 
{
    Scanner input = new Scanner(System.in);
    int count = 0;
    boolean switched = true;
    int[]a = new int[10];
    for (int i = 0; i < a.length; i++)
    {
        int value = input.nextInt();
        a[i] = value;
    }
    System.out.println(a[0]);
    while (switched == true)
    {
        switched = false;
        for (int i = 0; i < a.length; i++)
        {
            if (a[i] > a[i + 1]) 
            {
                int temp = a[i];
                a[i] = a[i + 1];
                a[i + 1] = temp;
                count++;
                switched = true;
            }
        }
        for (int i = a.length; i >= 0; i++)
        {
            if (a[i] > a[i + 1]) 
            {
                int temp = a[i];
                a[i] = a[i + 1];
                a[i + 1] = temp;
                count++;
                switched = true;
            }
        }
        if (switched == false)
        {
            System.out.println(count);
        }
    }

}

}

java arrays sorting
1个回答
1
投票

你需要改变

if (a[i] > a[i + 1])to是这样的 - > if (i < a.length-1 && a[i] > a[i + 1])

问题是它试图达到第11个元素;)

如果可以,这是您的代码的编辑版本:

Scanner input = new Scanner(System.in);
    int count = 0;
    boolean switched = true;


    int[]a = new int[10];
    System.out.println("enter 10 Integers: ");// # Added to make code clearer
    for (int i = 0; i < a.length; i++)
    {

        int value = input.nextInt();
        a[i] = value;
    }
        System.out.println("thankyou, Sorting now!");//# also this one 
    while(switched == true)
    {
        switched = false;
        for (int i = 0; i < a.length; i++)
        {
            if (i < a.length-1 && a[i] > a[i + 1]) // <-- # here was the problem
            {
                int temp = a[i];
                a[i] = a[i + 1];
                a[i + 1] = temp;
                count++;
                switched = true;
            }
        }
        for (int i = a.length; i >= 0; i++)
        {
            if (i < a.length-1 && a[i] > a[i + 1]) //<-- # Also Here 
            {
                int temp = a[i];
                a[i] = a[i + 1];
                a[i + 1] = temp;
                count++;
                switched = true;
            }
        }
        if (switched == false)
        {
            System.out.println("count is "+ count);
        }
    }
    // # added part to print array for testing 
        System.out.println("Sorted Array:");
        for (int i = 0; i <a.length ; i++) {


            System.out.print(a[i]+", ");
        }


    }//main 

}//class

这是输出:

OUTPUT

复制并粘贴它,运行和快乐编码= D.

© www.soinside.com 2019 - 2024. All rights reserved.