-2

这段代码:

private int GetColumnToPopulate(int columnBase, int offset) {
    int duckbillColNum = 0;
    switch (columnBase) {
        case 0:
            duckbillColNum = 1;
            break;
        case 1:
            duckbillColNum = 5;
            break;
        case 2:
            duckbillColNum = 9;
            break;
        case 3:
            duckbillColNum = 13;
            break;
        case 4:
            duckbillColNum = 17;
            break;
        case 5:
            duckbillColNum = 21;
            break;
        case 6:
            duckbillColNum = 25;
            break;
        case 7:
            duckbillColNum = 29;
            break;
    }
    duckbillColNum += offset;
    return duckbillColNum;
}

...很容易理解,但冗长而笨拙。我想精简它。我的伪代码想法是这样的:

int[] colBases
{
    0..7
}
int[] offsets
{
    1,5,9,13,17,21,25,29
}
int idx = colBases.IndexOf(columnBase);
duckbillColNum = offsets[idx];

...或者也许是一个多维 int 数组?无论如何,“IndexOf”业务当然不会编译[ile,ute]。

4

4 回答 4

5

怎么样:

private int GetColumnToPopulate(int columnBase, int offset) {
   return (columnBase * 4) + 1 + offset;
}
于 2012-10-11T19:04:13.183 回答
2

考虑使用 a Dictionary,您可以像这样定义它:

Dictionary<int, int> offsets = new Dictionary<int, int>()
    {
        { 0, 1 },
        { 1, 5 },
        { 2, 9 },
        { 3, 13 },
        { 4, 17 },
        { 5, 21 },
        { 6, 25 },
        { 7, 29 },
    }

然后在使用时:

return offsets[columnBase];
于 2012-10-11T19:07:25.863 回答
1

在我看来,您应该用这个表达式替换开关,duckbillColNum = columnBase*4 +1;不是吗?

于 2012-10-11T19:04:05.583 回答
1

这只是一个简单的数学模式:

private int GetColumnToPopulate(int columnBase, int offset) 
{ return 1 + (columnBase * 4) + offset; }
于 2012-10-11T19:04:08.297 回答