1
クリティカルパス方式を使用してクリティカルパスを計算しようとしています。いくつかのテストケースがあり、出力は "tarea2.out"というファイルに出力する必要があります。テストケースの出力をオーバーライドしてJavaでテキストファイルに書き込む
問題は、私がファイルを印刷すると、それぞれのケースの出力を上書きして、最終的には最後のものしか表示しないように見えることです。私はそれが愚かだけど、私は、Javaに新たなんだと私は出力が正しいことはできません
ここに私のコードです:
package tarea;
import java.io.*;
import java.util.Arrays;
import java.util.StringTokenizer;
/**
*
* @author Francisco
*/
public class Main {
public static int c;
public static void recorrido(int[][] adj) throws IOException{
int n=adj.length;
int casitas[][] = new int[n][2];
int mejorCamino[] = new int [n];
int temp;
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
temp = adj[i][j];
if(temp > -1){
if(temp + casitas[i][0]>casitas[j][0]){
casitas[j][0] = temp + casitas[i][0];
mejorCamino[j] = i;
}
}
}
}
//Hacemos el paso hacia atrás.
for(int y=0;y<n;y++)
casitas[y][1] = casitas[n-1][0];
for (int j=n-1;j>=0;j--){
for(int i=0;i<n;i++){
temp = adj[i][j];
if(temp > -1){
casitas[i][1]= Math.min(casitas[j][1] - temp , casitas[i][1]);
}
}
}
int x=n-1;
String cam = "";
while(x>0){
if(x==n-1)
cam= mejorCamino[x] + " " + x;
else
cam= mejorCamino[x] + " " + x + "\n" + cam;
adj[mejorCamino[x]][x] = -1;
x = mejorCamino[x];
}
//Calculamos las holguras con nuestra nueva matriz
String mac="";
int HT , HL;
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
temp = adj[i][j];
if (temp > -1){
HT = casitas[j][1] - temp - casitas[i][0];
HL = casitas[j][0] - temp - casitas[i][0];
mac += "\n" + i + " " + j + " " + HT + " " + HL;
if (HT>HL)
mac += " R";
}
}
}
String sFichero = "tarea2.out";
File fichero = new File(sFichero);
BufferedWriter bw = new BufferedWriter(new FileWriter(sFichero));
bw.write("Case " + c + ": total duration " + casitas[n-1][0]);
bw.write("\n");
bw.write(cam);
bw.write(mac);
bw.write("\n");
// Hay que cerrar el fichero
bw.close();
}
}