在数组中查找列总数

时间:2013-05-21 11:54:38

标签: c# java c++ arrays grid

我有一个带有随机元素的一维数组,通过一个m * n网格。我想找出行中的总行数和列总数。

以下是1维数组的方式: [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20]

我想把它当作:

01 02 03 04 05

06 07 08 09 10

11 12 13 14 15

16 17 18 19 20

现在我想找到reo total和column total。 行总计如下:

for (int i = 0; i < totalRows; i++)
        {
            for (int j = 0; j < totalColumns; j++)
            {
                rowTotal[i] += numbers[temp + j];
            }               
            temp += totalColumns;
        }

我正在尝试用Column做同样的事情。 这是代码:

for (int i = 0; i < totalColumns; i++)
        {
            tempk = 0;

            for (int j = 0; j < totalRows; j++)
            {
                blockTotal[i] += numbers[i+j+tempk];
               tempk += totalColumns;

            }
        }

无法按预期获得列总数。请帮助。

3 个答案:

答案 0 :(得分:3)

你可以在同一个循环中获得两者

for (int i = 0; i < totalRows; i++)
{
    for (int j = 0; j < totalColumns; j++)
    {
        rowTotal[i] += numbers[i * totalColumns + j];
        blockTotal[j] += numbers[i * totalColumns + j];
    }            
}

答案 1 :(得分:1)

最简单的方法是编写一个将“逻辑”(row,col)地址转换为索引的小方法:

int numberAt(int row, int col)
{
    return numbers[row * totalColumns + col];
}

int[] colTotals = new int[totalColumns];
int[] rowTotals = new int[totalRows];

for (int row = 0; row < totalRows; ++row)
{
    for (int col = 0; col < totalColumns; ++col)
    {
        int number = numberAt(row, col);
        rowTotals[row] += number; 
        colTotals[col] += number;
    }
}

编辑以回应下面评论中的问题:

这是一个完整的可编译示例,演示了它在非正方形数组上的工作:

using System;
using System.Collections.Generic;
using System.Linq;

namespace Demo
{
    class Program
    {
        // Array will 4x3 (rows x cols):
        //
        //  1  2  3 |  6
        //  4  5  6 | 15
        //  7  8  9 | 24
        // 10 11 12 | 33
        // ---------
        // 22 26 30

        int[] numbers = Enumerable.Range(1, 12).ToArray();
        int totalColumns = 3;
        int totalRows    = 4;

        int numberAt(int row, int col)
        {
            return numbers[row * totalColumns + col];
        }

        void test()
        {
            int[] colTotals = new int[totalColumns];
            int[] rowTotals = new int[totalRows];

            for (int row = 0; row < totalRows; ++row)
            {
                for (int col = 0; col < totalColumns; ++col)
                {
                    int number = numberAt(row, col);
                    rowTotals[row] += number;
                    colTotals[col] += number;
                }
            }

            Console.WriteLine("Row totals");

            foreach (int rowTotal in rowTotals)
                Console.Write(rowTotal + " ");

            Console.WriteLine("\nCol totals");

            foreach (int colTotal in colTotals)
                Console.Write(colTotal + " ");

            Console.WriteLine();
        }

        static void Main()
        {
            new Program().test();
        }
    }
}

答案 2 :(得分:0)

按行数总计

for(int r = 0; r < totalRows; r++)
{
  for(int c = 0; c < totalColumns; c++)
  {
    rowTotal[r] += numbers[r * totalColumns + c];
  }
}

按列总计

for(int c = 0; c < totalColumns; c++)
{
  for(int r = 0; r < totalRows; r++)
  {
    colTotal[c] += numbers[r * totalColumns + c];
  }
}