มีวิธีดั้งเดิมในการจัดเรียง String ตามเนื้อหาใน java หรือไม่? เช่น
String s = "edcba" -> "abcde"
มีวิธีดั้งเดิมในการจัดเรียง String ตามเนื้อหาใน java หรือไม่? เช่น
String s = "edcba" -> "abcde"
คำตอบ:
toCharArray
ตามด้วยArrays.sort
การเรียกใช้ตัวสร้างสตริง:
import java.util.Arrays;
public class Test
{
public static void main(String[] args)
{
String original = "edcba";
char[] chars = original.toCharArray();
Arrays.sort(chars);
String sorted = new String(chars);
System.out.println(sorted);
}
}
แก้ไข: ตามที่แทคไลน์ชี้ให้เห็นสิ่งนี้จะล้มเหลวหากสตริงมีคู่ตัวแทนหรืออักขระผสม (เน้น + e เป็นอักขระแยก) เป็นต้น ณ จุดนั้นมันจะยากขึ้นมาก ... หวังว่าคุณจะไม่ต้องการสิ่งนี้ :) นอกจากนี้นี่เป็นเพียงการเรียงลำดับตามลำดับโดยไม่ต้องคำนึงถึงตัวพิมพ์ใหญ่สำเนียงหรือสิ่งอื่นใด
sorted
เป็นแล้วString
... คุณคาดหวังว่าจะเรียกร้องtoString()
ให้ทำอะไร?
char[] c = s.toCharArray(); Arrays.sort(c); String sorted = new String(c);
ไม่มีวิธีสตริงในตัว คุณสามารถแปลงเป็นอาร์เรย์ถ่านจัดเรียงโดยใช้ Arrays.sort และแปลงกลับเป็นสตริง
String test= "edcba";
char[] ar = test.toCharArray();
Arrays.sort(ar);
String sorted = String.valueOf(ar);
หรือเมื่อคุณต้องการจัดการอย่างถูกต้องกับสิ่งที่ระบุสถานที่เช่นตัวพิมพ์ใหญ่และอักขระเน้นเสียง:
import java.text.Collator;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Locale;
public class Test
{
public static void main(String[] args)
{
Collator collator = Collator.getInstance(new Locale("fr", "FR"));
String original = "éDedCBcbAàa";
String[] split = original.split("");
Arrays.sort(split, collator);
String sorted = "";
for (int i = 0; i < split.length; i++)
{
sorted += split[i];
}
System.out.println(sorted); // "aAàbBcCdDeé"
}
}
ใน Java 8 สามารถทำได้ด้วย:
String s = "edcba".chars()
.sorted()
.collect(StringBuilder::new, StringBuilder::appendCodePoint, StringBuilder::append)
.toString();
ทางเลือกที่สั้นกว่าเล็กน้อยซึ่งใช้ได้กับ Stream of Strings ที่มีความยาว 1 ตัว (อักขระแต่ละตัวใน String ที่ไม่เรียงลำดับจะถูกแปลงเป็น String ใน Stream) คือ:
String sorted =
Stream.of("edcba".split(""))
.sorted()
.collect(Collectors.joining());
แปลงเป็นอาร์เรย์ของอักขระ → เรียง → แปลงกลับเป็นสตริง :
String s = "edcba";
char[] c = s.toCharArray(); // convert to array of chars
java.util.Arrays.sort(c); // sort
String newString = new String(c); // convert back to String
System.out.println(newString); // "abcde"
วิธีการที่ดิบมากขึ้นโดยไม่ต้องใช้วิธีการเรียงลำดับ Arrays.sort นี่คือการใช้การเรียงลำดับการแทรก
public static void main(String[] args){
String wordSt="watch";
char[] word=wordSt.toCharArray();
for(int i=0;i<(word.length-1);i++){
for(int j=i+1;j>0;j--){
if(word[j]<word[j-1]){
char temp=word[j-1];
word[j-1]=word[j];
word[j]=temp;
}
}
}
wordSt=String.valueOf(word);
System.out.println(wordSt);
}
String a ="dgfa";
char [] c = a.toCharArray();
Arrays.sort(c);
return new String(c);
โปรดทราบว่าสิ่งนี้จะไม่ทำงานตามที่คาดไว้หากเป็นสตริงกรณีผสม (จะใส่ตัวพิมพ์ใหญ่ก่อนตัวพิมพ์เล็ก) คุณสามารถส่งตัวเปรียบเทียบไปยังวิธีการเรียงลำดับเพื่อเปลี่ยนแปลงได้
ขั้นตอน:
ข้อมูลโค้ด:
String input = "world";
char[] arr = input.toCharArray();
Arrays.sort(arr);
String sorted = new String(arr);
System.out.println(sorted);
คำถาม: เรียงลำดับสตริงใน java
public class SortAStringInJava {
public static void main(String[] args) {
String str = "Protijayi";
// Method 1
str = str.chars() // IntStream
.sorted().collect(StringBuilder::new, StringBuilder::appendCodePoint, StringBuilder::append).toString();
System.out.println(str);
// Method 2
str = Stream.of(str.split(" ")).sorted().collect(Collectors.joining());
System.out.println(str);
}
}
public static void main(String[] args) {
String str = "helloword";
char[] arr;
List<Character> l = new ArrayList<Character>();
for (int i = 0; i < str.length(); i++) {
arr = str.toCharArray();
l.add(arr[i]);
}
Collections.sort(l);
str = l.toString();
System.out.println(str);
str = str.replaceAll("\\[", "").replaceAll("\\]", "")
.replaceAll("[,]", "");
System.out.println(str);
}
โดยไม่ต้องใช้ Collections ใน Java:
import java.util.Scanner;
public class SortingaString {
public static String Sort(String s1)
{
char ch[]=s1.toCharArray();
String res=" ";
for(int i=0; i<ch.length ; i++)
{
for(int j=i+1;j<ch.length; j++)
{
if(ch[i]>=ch[j])
{
char m=ch[i];
ch[i]=ch[j];
ch[j]=m;
}
}
res=res+ch[i];
}
return res;
}
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("enter the string");
String s1=sc.next();
String ans=Sort( s1);
System.out.println("after sorting=="+ans);
}
}
เอาท์พุท:
ป้อนสตริง ==
การเรียงลำดับ
หลังจากการเรียงลำดับ == ginorst