有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

在Java中解析文本文件时出现问题

我已经看了所有的链接,似乎无法得到我要找的。我有一个文本文件需要读入。首先是文本文件格式:

3 STL NY Chi //all on one line
STL NY 575 //on its own line
NY Chi 550 //on its own line
STL Chi 225 //on its own line

我需要将int读入一个int变量,比如我们称之为count。然后将同一条线上的实际城市排列成一个数组。接下来的几行需要读入一个数组,其中里程数与数组相关联,例如[STL NY]=575。我只能使用数组。没有哈希表、列表、堆栈或队列。这是我到目前为止得到的,老实说,这并不多。我真的需要一些帮助,因为我在这件事上“怎么做”的问题上很困惑

import java.io.*;
import java.util.*;

public class P3 {

/**
 * @param args the command line arguments
 */
public static int count;

public static void main(String[] args) {

    try {

        FileInputStream dataFile = new FileInputStream("Data.txt");
        //BufferedReader br = new BufferedReader(new InputStreamReader(dataFile));

        String line = br.readLine();

    }

    catch (IOException e) {
        System.err.println ("Unable to open file");
        System.exit(-1);
    }
  }
}

我想我已经做到了,但是我得到了一个错误代码:“不能从静态上下文引用非静态变量城市。”我试图通过打印来测试我的代码。有人能帮我印刷吗?我想看看数组中有什么,以确保我做得正确。这是我的密码:

package p3;

import java.io.*;
import java.util.*;



class citiesDist {
    String cityOne;
    String cityTwo;
    int miles;
}

class city {
    String cityName;
    int numberLinks;
    citiesDist[] citiesDists;
}

public class P3 {

    city[] cities;

    void initCity(int len) {
        for (int i = 0; i < len; i++) {
            cities[i] = new city();
        }
    }

    void initCitiesDist (int index, int len) {
        for (int i = 0; i < len; i++) {
            cities[index].citiesDists[i] = new citiesDist();
        }
    }

    void parseFile() throws FileNotFoundException, IOException { 
        FileInputStream fstream = new FileInputStream("Data.txt"); 
        DataInputStream in = new DataInputStream(fstream); 
        BufferedReader br = new BufferedReader(new InputStreamReader(in)); 

        int numberCities = Integer.parseInt(br.readLine());
        cities = new city[numberCities];
        initCity(numberCities);

        for (int i = 0; i < numberCities; i++) {
            String line = br.readLine();
            int numberLink = Integer.parseInt(line.split(" ")[1]);
            cities[i].cityName = line.split(" ")[0];
            cities[i].numberLinks = numberLink;
            initCitiesDist (i, numberLink);

            for (int j = 0; j < numberLink; j++){
                line = br.readLine();
                cities[i].citiesDists[j].cityOne = line.split(" ")[0];
                cities[i].citiesDists[j].cityTwo = line.split(" ")[1];
                cities[i].citiesDists[j].miles = Integer.parseInt(line.split(" ")[2]);
            }
        }

    }

    public static void main(String args[]) {
        System.out.println("city" + cities.city);
    }
}

共 (1) 个答案

  1. # 1 楼答案

    如果你曾经被代码难倒,不要考虑编程语言;这只会进一步混淆你的逻辑。(将算法与语言分开。)当你清楚地知道你想要完成什么时,加入你的语言(比如,“我如何完成这个特定任务?”)

    最终目标

    从您的设计中,您的目标是拥有一个与每个城市之间的距离相关的图表。它看起来像这样:

         [STL][NY] [Chi]
    [STL][0]  [575][25]
    [NY] [575][0]  [550]
    [Chi][25] [550][0]
    

    就文件输入和^{}类而言,这并不太难实现

    第一步

    您必须提取图形的维度(3乘3)。这在输入文件的第一行中为您提供。从含有FileScanner中获取整数并不太困难,只要确保导入了正确的类,以及正确的错误处理(或者try...catch或者抛出异常)

    Scanner sc = new Scanner(new File("input.txt"));
    

    您需要两个阵列—一个用于城市,另一个用于距离本身。我们不知道它们有多大(你从不假设文件中的数据,你只假设数据的形式),所以我们必须从文件本身获取数据。幸运的是,我们得到了一个整数,后跟城市本身。我们将读取此整数一次,并在多个不同位置使用它

    String[] cities = new String[sc.nextInt()];
    int[][] distances = new int[cities.length][cities.length];
    for(int i = 0; i < cities.length; i++) {
        // Surely there's a method in Scanner that returns String that reads the _next_ token...
    }
    

    这个练习是给读者听的

    现在,您已经设置好数据结构并准备就绪。从这里开始,您需要做的是弥合城市阵列和距离阵列之间的差距。考虑他们到达文件的顺序,以及我们遇到的顺序。你可以用一些方法或方式来回答这个问题,“STL和NY哪个先到?”

    试一试,看看你是否能走得更远