上机题
1.将文件中每一行字符反序
【问题描述】对于一个文本文件text1.dat,编写一个程序,将该文件中的每一行字符颠倒顺序后输出到另一个文件text2.dat中。
【输入文件】输入文件为当前目录下的text1.dat,该文件含有多行任意字符,也可能有空行。每个文本行最长不超过80个字符。在最后一行的结尾也有一个回车符。
【输出文件】输出文件为当前目录下的text2.dat。
【样例输入】设输入文件text1.dat为:
This is a test!
Hello, world!
How are you?
【样例输出】输出文件text2.dat为:
!tset a si sihT
!dlrow ,olleH
?uoy era woH
【样例说明】将输入文件反序输出。
【评分标准】输出文件应与输入文件的字符个数相等,并且符合题目规定的格式。如果你的程序输出正确,该测试点得满分,否则该测试点不得分。
代码如下:
import java.io.*;
public class Homework_1 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new FileReader("text1.dat"));
BufferedWriter bw = new BufferedWriter(new FileWriter("text2.dat"));
String line;
while ((line = br.readLine()) != null) {
bw.write(new StringBuffer(line).reverse().toString());
bw.newLine();
}
br.close();
bw.close();
}
}
2.单词排序
【问题描述】
编写一个程序,从一个文件中读入单词(即:以空格分隔的字符串),并对单词进行排序,删除重复出现的单词,然后将结果输出到另一个文件中。
【输入形式】
从一个文件sort.in中读入单词。
【输出形式】
对单词进行排序,删除重复出现的单词,然后将结果输出到文件sort.out中。
【输入样例】
假如sort.in文件内容如下:
rrr sss aaa bbb ccc ddf aaa dd
【输出样例】
sort.out文件内容为:
aaa bbb ccc dd ddf rrr sss
【样例说明】
读入文件sort.in,做适当的排序,并删除重复出现的单词,输出到文件sort.out
【评分标准】
对单词进行排序,删除重复出现的单词,符合此要求得20分,每个测试点4分。
代码如下:
import java.io.*;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
public class Homework_2 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new FileReader("sort.in"));
String line = br.readLine();
String[] words = line.split(" ");
br.close();
Arrays.sort(words);
List<String> list = new ArrayList<>();
for (String word : words) {
if (!list.contains(word)) {
list.add(word);
}
}
BufferedWriter bw = new BufferedWriter(new FileWriter("sort.out"));
for (String word : list) {
bw.write(word + " ");
}
bw.close();
}
}
博主java萌新,有问题可评论区共同交流学习,欢迎大家交流awa