[英]Having trouble figuring out how to pass a file through my method
在這個程序中,我正在處理的是通過我的名為 homophone 的方法讀取文件,該方法讀取文件並使用哈希圖來查找具有最多同音字的單詞並返回最多的同音字數。 我的問題是如何讀取文件並通過主方法中的同音方法傳遞它。 到目前為止,這是我的代碼:
import java.security.KeyStore.Entry;
import java.util.*;
import java.io.*;
public class program2 {
public static void main(String[] args) throws IOException {
System.out.println(homophone());
}
public static int homophone(String file) throws FileNotFoundException{
HashMap<String,Integer> alike = new HashMap<>();
Scanner input = new Scanner(new File(file));
while(input.hasNext()) {
String line = input.nextLine();
String[] key = line.split(" ");
if(alike.containsKey(key[1])) {
alike.put(key[1],alike.get(key[1])+1);
} else alike.put(key[1],alike.get(key[1]));
}
int max = 0;
for(java.util.Map.Entry<String, Integer> e:alike.entrySet()) {
if(e.getValue()>max) max = e.getValue();
}
return max;
}
}
Example File Content:
A AH0
A(1) EY1
A'S EY1 Z
A. EY1
A.'S EY1 Z
A.S EY1 Z
A42128 EY1 F AO1 R T UW1 W AH1 N T UW1 EY1 T
AAA T R IH2 P AH0 L EY1
AABERG AA1 B ER0 G
AACHEN AA1 K AH0 N
AACHENER AA1 K AH0 N ER0
AAKER AA1 K ER0
AALSETH AA1 L S EH0 TH
AAMODT AA1 M AH0 T
AANCOR AA1 N K AO2 R
AARDEMA AA0 R D EH1 M AH0
AARDVARK AA1 R D V AA2 R K
AARON EH1 R AH0 N
AARON'S EH1 R AH0 N Z
AARONS EH1 R AH0 N Z
您需要將一個字符串傳遞給您的同音方法,如下所示:
System.out.println(homophone("/folder/file.txt"));
或者
System.out.println(homophone(args[0]));
使用第二個,你需要編譯和使用這樣的系統命令行:
java program2 "/folder/file.txt"
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.