行数不相等的多文件读取

时间:2018-06-26 08:00:46

标签: java arrays file binary-search

我有两个数据文件。数据是双重类型(例如90.0、25.63)。 File1由3列和几行组成,而File2由4列和几行组成。我在一个Java程序中分别从两个文件中读取数据,并且File1的Column1数据与File2的Column1数据匹配,然后一条消息将显示数据已匹配,否则数据不匹配。第一数据文件中的行数与第二数据文件中的行数不同。如果在第4行中找到匹配项,则第4行之前的数据将按原样写入,而在第4行中将记录There is match

示例:

文件1:

 2.0   0.6258  0.239  1.852
 3.0   0.5289  0.782  2.358
 5.0   1.2586  2.3658 0.1258
 6.0   0.235   0.8547 3.5870

文件2:

5.0  0.8974  1.2358  0.2581  
7.0  0.3258  0.6528  0.6987

File2中的行数低于File1中的行数。 File1和File2的第一列的所有数据都按升序排列。

我想照原样写2.03.0。然后从File2找到一个匹配项,因此它将写入“ Match found”,然后按原样写入File1中的6.0。然后再次搜索是否找到匹配项,然后再次写下“找到匹配项”。

代码:

import java.io.File;
import java.util.Scanner;

public class F1 {
    public static void main(String args[])throws Exception{
        Scanner Y =new Scanner(new File("C:\\File1.txt"));
        Scanner X =new Scanner(new File("C:\\File.txt"));
        double a=0.0,b=0.0,c,d=0.0,e=0.0,f,g,h;
        while (X.hasNext() && Y.hasNext()) {
            a = X.nextDouble();
            System.out.println(a);//1st row of file1,2nd row of file1.... So lastly some rows at the end of the file will be discard
            b = X.nextDouble();

            c = X.nextDouble();

            d = Y.nextDouble();
            System.out.println(e);// 1st row of file2. Every row print as the number of row is less than File1.
            e = Y.nextDouble();

            f = Y.nextDouble();
            g = Y.nextDouble();

            if(a==d) {
                System.out.println("They are matched");
            }
            else{
                System.out.println("Not Matched");
            }
        }
    }
}

我需要执行任何搜索程序吗?喜欢Binarsearch?在Java中,有一个过程Arrays.Binarysearch(array,key)。因此,要实现这一点,我需要将a变量存储在数组中。然后,将该数组的每个单元格与d进行比较。那是正确的程序吗?

1 个答案:

答案 0 :(得分:0)

如果文件按第一列排序或保证具有相同顺序的元素,则您选择的方法将起作用。

如果不是这种情况,则必须先将文件读入内存(例如,每个文件List<Double>),然后比较列表的内容,例如,通过对列表进行排序,然后将元素与元素进行比较(同时记住浮点比较可能比较棘手)。如果保证每个文件的值都是唯一的,则可以对每个文件使用Set并直接比较集合。