这是我的函数,假设从“in1.txt”中获取值,并将它们输出到“out1.txt”中,并附上说明是否为素数的说明。
代码:
import java.util.Scanner;
import java.util.ArrayList;
import java.io.File;
import java.io.PrintWriter;
public class task1
{
public static boolean isPrime(int n) {
if (n <= 1) {
return false;
}
for (int i = 2; i < Math.sqrt(n); i++) {
if (n % i == 0) {
return false;
}
}
return true;
}
public static ArrayList<String> check_primes(String in_file, String out_file)
{
File temp = new File(in_file);
Scanner input_file;
String filename = "out1.txt";
PrintWriter out = null;
try
{
input_file = new Scanner(temp);
out = new PrintWriter(filename);
}
catch (Exception e)
{
System.out.printf("Failed to open file %s\n",in_file);
return null;
}
ArrayList<String> result = new ArrayList<String>();
while(input_file.hasNextLine())
{
String line = input_file.nextLine();
result.add(line);
for(int i = 0; i<result.size();i++)
{
String x = result.get(i);
int xx = Integer.parseInt(x);
if(isPrime(xx))
{
out.printf(xx + " is a prime\r\n");
}
else
{
out.printf(xx + " is not a prime\r\n");
}
}
out.close();
}
input_file.close();
return result;
}
public static void main(String[] args)
{
check_primes("in1.txt", "out1.txt");
System.out.printf("Exiting...\n");
}
}
它只添加了int1文件的第一个值,我假设它是某种循环错误或者我在循环中丢失了一些东西。我测试看是否有“x”或“xx”的错误,并打印出来,x将打印出[7] [7,10] [7,10,13]等形成金字塔,和xx以与7 \ n 7 \ n 10 \ n 7 \ n 10 \ n 13 \ n类似的方式打印出来 有人可以帮我找出问题所在吗?
答案 0 :(得分:2)
我认为有一个循环然后将每行添加到列表中的意图是稍后处理包含所有行的列表。如果是这样,那么您需要在while循环中包含 result.add(line)并关闭它。之后在for循环中处理所有行
while (input_file.hasNextLine()) {
String line = input_file.nextLine();
result.add(line);
} //close the loop here
假设您没有关闭while循环。由于 result.size()为1,for循环只执行一次,在for循环完成后,它将关闭输出流。
答案 1 :(得分:0)
while(input_file.hasNextLine()) {
String line = input_file.nextLine();
result.add(line);
}
for(int i = 0; i<result.size();i++)
{
String x = result.get(i);
int xx = Integer.parseInt(x);
if(isPrime(xx))
{
out.printf(xx + " is a prime\r\n");
}
else
{
out.printf(xx + " is not a prime\r\n");
}
}
out.close();