2

我有一个包含单词列表的文本文件,我需要使用 Java 按字母顺序对其进行排序。这些词位于单独的行上。

我将如何解决这个问题,将它们读入数组列表然后对其进行排序?

4

3 回答 3

7

这是一个简单的四步过程,Stackoverflow Questions 解决了四个步骤中的三个:

  1. 读取每一行并将它们转换为 Java 字符串
  2. 将每个 Java 字符串存储在一个数组中(不要认为您需要对此的引用。)
  3. 对数组进行排序
  4. 写出数组中的每个 Java 字符串
于 2013-03-27T00:31:35.230 回答
0
import java.io.*;
import java.util.*;

public class example
{
    TreeSet<String> tree=new TreeSet<String>();
    public static void main(String args[])
    {
        new example().go();
    }
    public void go()

    {
        getlist();
        System.out.println(tree);

    }
     void getlist()
    {
        try
        {
            File myfile= new File("C:/Users/Rajat/Desktop/me.txt");
            BufferedReader reader=new BufferedReader(new FileReader(myfile));
            String line=null;
            while((line=reader.readLine())!=null){
                addnames(line);


            }
        reader.close();
        }

        catch(Exception ex)
        {
            ex.printStackTrace();
        }

    }
    void addnames(String a)
    {
           tree.add(a);
           for(int i=1;i<=a.length();i++)
           {

           }
    }
}
于 2013-07-12T07:50:15.373 回答
0

这是使用集合排序的示例:

public static void sortFile() throws IOException
{     
    FileReader fileReader = new FileReader("C:\\words.txt");
    BufferedReader bufferedReader = new BufferedReader(fileReader);
    List<String> lines = new ArrayList<String>();
    String line = null;
    while ((line = bufferedReader.readLine()) != null) {
        lines.add(line);
    }
    bufferedReader.close();

    Collections.sort(lines, Collator.getInstance());

    FileWriter writer = new FileWriter("C:\\wordsnew.txt"); 
    for(String str: lines) {
      writer.write(str + "\r\n");
    }
    writer.close();
}

您也可以像这样使用自己的排序规则:

Locale lithuanian = new Locale("lt_LT");
Collator lithuanianCollator = Collator.getInstance(lithuanian);
于 2015-04-15T16:11:37.293 回答