首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Java冒泡排序算法的实现

Java冒泡排序算法的实现
EN

Stack Overflow用户
提问于 2016-12-12 04:13:38
回答 2查看 413关注 0票数 0

我正在尝试将冒泡排序算法实现到我的代码中,以使输出按升序显示。下面是我的代码,后面是我在JGrasp中收到的错误。任何建议或指示都将不胜感激。

代码语言:javascript
复制
import java.util.*;

public class RandomArray
{
   public static void main(String[] args)
   {
      Scanner input = new Scanner(System.in);
      System.out.println("Please enter the number 15 to generate 15 random numbers!");
      int randomIn = input.nextInt();
      int[] randomNumbers = new int[randomIn];
      if(randomIn != 15)
      {
         System.out.println("The number you entered was not 15. Please run the program again and enter 15...");
      }
      else if(randomIn == 15)
      {
         for(int x = 0; x < randomNumbers.length; ++x)
         {
            randomNumbers[x] = (int) (Math.random()*50);
            System.out.println("Your randomly generated numbers are: " + randomNumbers[x]);
         }
      }

   }
   public static void bubbleSort(int[] randomNumbers)
      {
         int n = randomNumbs.length;
         int temp = 0;
         for(int i = 0; i < n; i++)
            {
               for(int j = 1; j < (n - 1); j++)
               {
                  if(randomNumbers[j-1] > randomNumbers[j])
                     {
                        temp = randomNumbers[j - 1];
                        randomNumbers[j - 1] = randomNumbers[j];
                        randomNumbers[j] = temp;
                        for(int i=0); i<randomNumbers.length; i++)
                        {
                           System.out.print(randomNumbers[i] + " ");
                        }
                     } 
               }
            }
      }


}

我收到的错误是:

代码语言:javascript
复制
----jGRASP exec: javac -g RandomArray.java
RandomArray.java:38: error: ';' expected
                        for(int i=0); i<randomNumbers.length; i++)
                                   ^
RandomArray.java:38: error: not a statement
                        for(int i=0); i<randomNumbers.length; i++)
                                       ^
RandomArray.java:38: error: ')' expected
                        for(int i=0); i<randomNumbers.length; i++)
                                                            ^
RandomArray.java:38: error: ';' expected
                        for(int i=0); i<randomNumbers.length; i++)
                                                                 ^
4 errors

 ----jGRASP wedge2: exit code for process is 1.
 ----jGRASP: operation complete.
EN

回答 2

Stack Overflow用户

发布于 2016-12-12 04:26:22

这就是实现冒泡排序的方法。我只是写了一个返回数组的方法。这将使您的数字按升序排列:

代码语言:javascript
复制
public int []bubbleSort(int[] arr) {
      int size = arr.length;
      for (int pass = 1; pass < size; pass++) {
         for (int i = 0; i < size-pass; i++) {
            if (arr[i] > arr[i+1]) {
               int temp = arr[i];
               arr[i] = arr[i+1];
               arr[i+1] = temp;
            }
         }

      }
      return arr;
   }
票数 1
EN

Stack Overflow用户

发布于 2016-12-12 04:36:44

我想你应该生成15个随机数,然后按加入顺序打印出来。

下面是代码。

代码语言:javascript
复制
import java.util.*;
public class RandomArray
{
   public static void main(String[] args)
   {
      Scanner input = new Scanner(System.in);
      System.out.println("Please enter the number 15 to generate 15 random numbers!");
      int randomIn = input.nextInt();
      int[] randomNumbers = new int[randomIn];
      if(randomIn != 15)
      {
         System.out.println("The number you entered was not 15. Please run the program again and enter 15...");
      }
      else if(randomIn == 15)
      {
         for(int x = 0; x < randomNumbers.length; ++x)
         {
            randomNumbers[x] = (int) (Math.random()*50);
            System.out.println("Your randomly generated numbers are: " + randomNumbers[x]);
         }
         bubbleSort(randomNumbers);
      }

   }
   public static void bubbleSort(int[] randomNumbers)
      {
         int n = randomNumbers.length;
         int temp = 0;
         for(int i = 0; i < n; i++)
            {
               for(int j = 1; j < (n - 1); j++)
               {
                  if(randomNumbers[j-1] > randomNumbers[j])
                     {
                        temp = randomNumbers[j - 1];
                        randomNumbers[j - 1] = randomNumbers[j];
                        randomNumbers[j] = temp;                    
                     } 
               }
            }
            for(int k=0; k<randomNumbers.length; k++)
            {
            System.out.print(randomNumbers[k] + " ");
            }
      }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41090670

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档