簡體   English   中英

按降序對字符串進行冒泡排序

[英]Bubble sort strings in descending order

我必須在冒泡排序中按降序對一串名稱進行排序。 我試過了,但沒有用。 這是我到目前為止所擁有的:

public static void bubbleSort(Student[] array)
{
    for(int i=(array.length); i>0; i--)
    {    
        for(int j=1; j<(array.length-i); j++) 
        {
            if( array[j].getName().compareTo(array[j+1].getName())<0)    
            {
                Student Temp = array[j];
                array[j] = array[j+1];
                array[j+1] = Temp;
            }    
        }
    }
}

試試這個邏輯

   import java.util.*;

    public class BubbleSort {

   public static void main(String[] args) {
    String l[]={"ABCD" , "XYZ" , "DEF" , "PQR"};
    BubbleSort(l);
    for(int i=0; i<l.length; i++)
    {
        System.out.println(l[i]);
    }
  }

 private static void BubbleSort(String[] array) {
    String t;
    for(int i=0; i<array.length; i++) {
        for(int j=0; j<array.length-1-i; j++) {
        if(array[j].compareTo(array[j+1])>0) {
            t= array[j];
            array[j] = array[j+1];
            array[j+1] = t;
        }
    }
    }
}
   }

我遲到了八年零一個月,但對於現在遇到同樣問題的任何人,這里是解決方案代碼:

import java.util.Scanner;
public class sort
{
    public static void main(String args[])
    {
        Scanner scnr=new Scanner(System.in);
        String arr[]= new String[20];
        
        System.out.println("Enter names:");
        for(int i=0; i<20; i++)
        {
            arr[i]= scnr.nextLine();
        }
        
        String temp; int i;
        for(int j=0; j<arr.length;j++)
        {
            for(i=j+1; i<arr.length; i++)
            {
                //comparing adjacent string
                if(arr[i].compareTo(arr[j]) > 0)
                {
                    temp=arr[j];
                    arr[j]=arr[i];
                    arr[i]=temp;
                }
            }
            System.out.println(arr[j]);
        }
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM