包含相同值的hashmap

时间:2013-06-26 17:01:59

标签: java matrix hashmap jama

嗨我使用包含整数作为键的hashMap和作为值的矩阵列表,这里是代码

    import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

import Jama.Matrix;


public class KFold {
public static HashMap<Integer,List<Matrix>> splitterDonnees(Matrix matReduite){
    int K =10;
    int unite = matReduite.getRowDimension()/K;
    int indexDebtest = 0;
    int indexFinTest = unite;
    Matrix matDonEntr = new Matrix(matReduite.getRowDimension()-unite,matReduite.getColumnDimension());
    Matrix matDonTest = new Matrix(unite,matReduite.getColumnDimension());
    HashMap<Integer,List<Matrix>> mapDonn = new HashMap<Integer,List<Matrix>>();

    for (int i =0;i<K;i++){
        int ireloaded = 0;
        int ireloadedEntr =0;
        for(int ii =indexDebtest; ii<indexFinTest;ii++){
            int jreloaded=0;
            for(int j =0;j<matReduite.getColumnDimension();j++){

                matDonTest.set(ireloaded, jreloaded, matReduite.get(ii, j));
                jreloaded++;
            }
            ireloaded++;

        }
        //matDonTest.print(10, 5);
        if(indexDebtest == 0){
            for(int ii =unite;ii<matReduite.getRowDimension();ii++){
                int jreloadedEntr=0;
                for(int j =0; j<matReduite.getColumnDimension();j++){
                    matDonEntr.set(ireloadedEntr, jreloadedEntr, matReduite.get(ii, j));
                    jreloadedEntr++;
                }
                ireloadedEntr++;
            }
        }

        else if (indexFinTest==matReduite.getRowDimension()){
            for(int ii =0;ii<matReduite.getRowDimension()-unite;ii++){
                int jreloadedEntr=0;
                for(int j =0; j<matReduite.getColumnDimension();j++){
                    matDonEntr.set(ireloadedEntr, jreloadedEntr, matReduite.get(ii, j));
                    jreloadedEntr++;
                }
                ireloadedEntr++;

            }
        }
        else{
            for(int ii=0;ii<indexDebtest;ii++){
                int jreloadedEntr=0;
                for(int j =0; j<matReduite.getColumnDimension();j++){
                    matDonEntr.set(ireloadedEntr, jreloadedEntr, matReduite.get(ii, j));
                    jreloadedEntr++;    
                }
                ireloadedEntr++;
            }
            for(int ii =indexFinTest;ii<matReduite.getRowDimension();ii++){
                int jreloadedEntr=0;
                for(int j =0; j<matReduite.getColumnDimension();j++){
                    matDonEntr.set(ireloadedEntr, jreloadedEntr, matReduite.get(ii, j));
                    jreloadedEntr++;

                }
                ireloadedEntr++;
            }
        }

        indexDebtest = indexDebtest+unite;
        indexFinTest = indexFinTest+unite;

        List<Matrix> coupleMatTest_MatEntr = new ArrayList<Matrix>();
        coupleMatTest_MatEntr.add(matDonTest);
        //matDonTest.print(10, 5);
        coupleMatTest_MatEntr.add(matDonEntr);
        mapDonn.put(i, coupleMatTest_MatEntr);
        //System.out.println("Les lements tests de mapDonnees sont:"+mapDonn.get(i).size());
        mapDonn.get(i).get(0).print(10, 5);
    }
    //mapDonn.get(0).get(0).print(10, 5);
    //mapDonn.get(1).get(0).print(10, 5);
    return mapDonn;
}
}

问题是返回的hashMaps的最终版本包含相同的最后一个矩阵的10倍,因为它在循环中运行良好,因为我每次都看到不同的值,但是一旦我在之前打印了值return,所有值现在都是相同的最后一个矩阵。

编辑:Matrix课程来自Jama Package。

1 个答案:

答案 0 :(得分:1)

在循环中移动以下两行:

Matrix matDonEntr = new Matrix(matReduite.getRowDimension()-unite,matReduite.getColumnDimension());
Matrix matDonTest = new Matrix(unite,matReduite.getColumnDimension());

这样你就可以在循环的每次迭代中创建new矩阵。否则,方法中只有这两个实例,并且您不断地更改它们,结束于对它们的最后状态的许多引用。