创建3x3矩阵并在从较小到较大的涡旋中排序数字

时间:2013-10-13 13:08:36

标签: c# matrix

我想创建一个带有输入数字的3x3矩阵,然后从较小到较大的订单号将它放在矩阵中,就像涡旋一样:1,2,3,4,5,6,7,8,9并且编号为1至0.0位置,2至0.1,3至0.2,4至1.2,5至2.2,6至2.1,7至2.0,8至1.0和9至1.1。

const int MATRIX_ROWS = 3;
        const int MATRIX_COLUMNS = 3;
        List<int> l = new List<int>(l);

        double[,] matrix = new double[MATRIX_ROWS, MATRIX_COLUMNS];
        for (int i = 0; i < MATRIX_ROWS * MATRIX_COLUMNS; ++i)
        {
            int input;
            Console.Write("Enter value");
            while (!int.TryParse(Console.ReadLine(), out input))
            {
                Console.Write("Enter correct value!");
            }
            l.Add(input);
        }
        l.Sort();
        for (int i = 0; i < MATRIX_ROWS; i++)
        {
            for (int j = 0; j < MATRIX_COLUMNS; j++)
            {
                matrix[i, j] = l[i * 3 + j];
            }

我从这样开始获取输入数字,我想为第二部分提供帮助。

2 个答案:

答案 0 :(得分:0)

正如我所看到的那样 - 您可以在开头的某处声明List<int> l,按l.Add(x);读取整个数据,然后执行l.Sort(),并在数据排序后填充您的矩阵。如果您还有其他问题,请与我们联系。

所以你会得到像

这样的东西
const int MATRIX_ROWS = 3;
const int MATRIX_COLUMNS = 3;
List<int> l = new List<int>();

double[,] matrix = new double[MATRIX_ROWS, MATRIX_COLUMNS];
for (int i = 0; i < MATRIX_ROWS * MATRIX_COLUMNS; ++i)
{
        double input;
        Console.Write("Enter value");
        while (!double.TryParse(Console.ReadLine(), out input))
        {
            Console.Write("Enter correct value!");
        }
        l.Add(input);
}
l.Sort();
for (int i = 0; i < MATRIX_ROWS; i++)
{
    for (int j = 0; j < MATRIX_COLUMNS; j++)
    {
        matrix[i, j] = l[i*3 + j];
    }
}

答案 1 :(得分:0)

这将为您呈现矩阵的“漩涡状”结果:

            List<int> nums = new List<int>();
            double[,] matrix = new double[3,3];
            for (int i = 0; i < 9; ++i)
            {
                double input;
                Console.Write("Enter value");
                while (!double.TryParse(Console.ReadLine(), out input))
                {
                    Console.Write("Enter correct value!");
                }
                nums.Add(int.Parse(input.ToString()));
            }
            nums.Sort();
            int block = 0;
            int[] order = new int[] { 0, 1, 2, 2, 2, 1, 0, 0, 1 };
            for (int i = 0 ; i < order.Length; i++)
            {
                switch (block)
                {
                    case 0:
                        matrix[block, order[i]] = nums[i];
                        if (i == 2)
                            block = 1;
                        break;
                    case 1:
                        if (i < order.Length - 3)
                        {
                            matrix[block, order[i]] = nums[i];
                            block = 2;
                        }
                        else
                            matrix[block, order[i]] = nums[i];
                        break;
                    case 2:
                        if(i == order.Length - 3)
                        {
                            matrix[block, order[i]] = nums[i];
                            block = 1;
                        }
                        else
                            matrix[block, order[i]] = nums[i];
                        break;

                }
            }

            Console.WriteLine("The Resulting Matrix is:");

            for (int row = 0, col = 0; row < 3; row++)
            {
                Console.WriteLine("row " + row + ": {0} - {1} - {2}", matrix[row, col], matrix[row, col + 1], matrix[row, col + 2]);
                col = 0;
            }

编辑:现在显示结果。