递归表/行生成器

use*_*479 1 java arrays recursion matrix

我正在艰难地绕着以下情况缠头.解释的最佳方式可能是例子

我有一个Map <Column,Set <Row >>对象.假设它包含以下数据:

ColumnA['abc','def']
ColumnB['efg','hij','klm']
ColumnC['nop']
ColumnD['qrs','tuv','wxy','zzz']
Run Code Online (Sandbox Code Playgroud)

我正在尝试生成以下输出:

Row1[abc,efg,nop,qrs]
Row2[abc,efg,nop,tuv]
Row3[abc,efg,nop,wxy]
Row4[abc,efg,nop,zzz]
Row5[abc,hij,nop,qrs]
Row6[abc,hij,nop,wxy]
etc...
Run Code Online (Sandbox Code Playgroud)

所以在这种情况下总共会有24行.

但是,列数和行数都是动态的.我觉得这需要以某种方式递归地进行,但我不知道从哪里开始.

任何帮助,将不胜感激.

更新 - 我做了一个似乎有用的树结构.

    DefaultMutableTreeNode root = new DefaultMutableTreeNode();
    Set<DefaultMutableTreeNode> curNodes = new HashSet<DefaultMutableTreeNode>();
    curNodes.add(root);

    final Set<Column> keys = map.keySet();
    for (final Column key : keys) {
        final Set<Row> rowSet = map.get(key);
        Set<DefaultMutableTreeNode> tmpNodes = new HashSet<DefaultMutableTreeNode>();
        for (final Row row : rowSet) {
            DefaultMutableTreeNode curNode = new DefaultMutableTreeNode();
            curNode.setUserObject(row);
            tmpNodes.add(curNode);
            for (DefaultMutableTreeNode n : curNodes) {
                n.add(curNode);
            }
        }
        curNodes = tmpNodes;
    }
Run Code Online (Sandbox Code Playgroud)

Joo*_*gen 5

我希望这不是一些学生的功课.

首先要保持地图键的顺序相同,使用a SortedMap,就像TreeMap.此外,在您的初始地图中,每一行只包含一个像'abc'的值.这里的递归是深度优先遍历.困难的是地图没有自然的遍历.其余的有todos/candidate和dones/result; 做一步改变数据,然后恢复它们.

在这里,我使用更为人熟知的List,但Stack会更好.

public List<Row> generateRows(SortedMap<Column, Set<Cell>> map) {
    List<Row> done = new ArrayList<Row>();
    List<Column> columnsToDo = new LinkedList<Column>(map.keySet());
    List<Cell> partialRow = new LinkedList<Cell>();
    generateRowsRec(map, columnsToDo, partialRow, done);
    return done;
}
void generateRowsRec(SortedMap<Column, Set<Cell>> map, List<Column> columnsToDo, List<Cell> partialRow, List<Row> done) {
    if (columnsToDo.isEmpty()) {
        done.add(new Row(partialRow));
        return;
    }
    Column firstColumn = columnsToDo.remove(0); // Step A
    for (Cell cell : map.get(firstColumn)) {
        partialRow.add(cell); // Step B
        generateRowsRec(map, columnsToDo, partialRow, done);
        partialRow.remove(partialRow.size() - 1); // Unstep B
    }
    columnsToDo.add(0, firstColumn); // Unstep A
}
Run Code Online (Sandbox Code Playgroud)