【发布时间】:2021-06-29 06:26:58
【问题描述】:
我正在尝试找到一种方法对如下所示的文本文件进行冒泡排序:
04/26/16 Sega 3D Classics Collection 07/14/16 Batman: Arkham Underworld 06/24/16 Tokyo Mirage Sessions #FE
基本上我希望它们按照发布日期的顺序排列,例如 2016 年 1 月 25 日发布的游戏会先于 2016 年 6 月 26 日发布的游戏,它会创建一个像这样的新文件:
04/26/16 Sega 3D Classics Collection 06/24/16 Tokyo Mirage Sessions #FE 07/14/16 Batman: Arkham Underworld
我确信会涉及到一个 for 循环,因为每一行都是具有交换方法的数组元素和一个临时值,以便比较交换顺序,但我想不出一种方法来编写新订单到新文件中。
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Scanner;
public class Main{
public static void main (String[]args) throws IOException{
File file = new File("releasedates.txt");
String[]arr;
arr = input(file);
output(file,arr);
}
public static String[]input (File file) throws FileNotFoundException{
String[]arr = new String[3];
Scanner sc = new Scanner(file);
for(int i = 0; i < arr.length; i++){
arr[i] = sc.nextLine();
}
return arr;
}
public static void output(File file, String[] info) throws IOException{
FileWriter writer = new FileWriter("fileName.txt");
for(String aString:info){
writer.write(aString);
}
writer.close();
}
public static void sortByMonth(String[]info){
String temp;
for (int j = 0; j < info.length; j++) {
for (int i = j + 1; i < info.length; i++) {
if (info[i].compareTo(info[j]) < 0) {
temp = info[j];
info[j] = info[i];
info[i] = temp;
}
}
}
}
}
【问题讨论】:
-
您的
sortByMonth是否按预期工作? -
必须是冒泡排序吗?您是否保证文件
releasedates.txt中的每一行都包含不同的月份?你保证文件releasedates.txt正好包含三行吗?我认为您的输出文件将在一行中包含所有数据。这就是你想要的吗? -
@Abra 好吧,我正在做的事情说我不允许在 java 中使用内置的排序方法,所以我只是使用冒泡排序作为我最熟悉的排序方法.我假设每行的日期就像一个数字,所以较小的数字会先出现
标签: java arrays string sorting methods