Pergunta

Isso está me deixando louco há alguns dias.Por que o seguinte não funciona?

    Dim arr(3, 3) As Integer

    For y As Integer = 0 To arr.GetLength(0) - 1
        For x As Integer = 0 To arr.GetLength(y) - 1
            arr(y, x) = y + x
        Next
    Next

Além disso, e se a matriz fosse assim?

{ {1, 2, 3},
  {4, 5, 6, 7, 8, 9, 9, 9},
  {5, 4, 3, 2}
}
Foi útil?

Solução

Ok, então o que você realmente precisa é de uma "matriz irregular".Isso permitirá que você tenha um "array que contém outros arrays de comprimentos variados".

  Dim arr As Integer()() = {New Integer() {1, 2, 3}, New Integer() {4, 5, 6, 7, 8, 9, 9, 9}, New Integer() {5, 4, 3, 2}}

  For x = 0 To arr.GetUpperBound(0)
      Console.WriteLine("Row " & x & " has " & arr(x).GetUpperBound(0) & " columns")
      For y = 0 To arr(x).GetUpperBound(0)
          Console.WriteLine("(" & x & "," & y & ") = " & arr(x)(y))
      Next
   Next

Saída:

Row 0 has 2 columns
(0,0) = 1
(0,1) = 2
(0,2) = 3
Row 1 has 7 columns
(1,0) = 4
(1,1) = 5
(1,2) = 6
(1,3) = 7
(1,4) = 8
(1,5) = 9
(1,6) = 9
(1,7) = 9
Row 2 has 3 columns
(2,0) = 5
(2,1) = 4
(2,2) = 3
(2,3) = 2

Outras dicas

Porque não existe dimensão '2' ou '3'.Deve ser .GetLength(1) em vez de .GetLength(y)

Também:nas declarações de array VB.Net funcionam de maneira um pouco diferente.O subscrito que você especifica na declaração é o último índice, não o número de itens criados como em C# ou C++.Mas a matriz ainda é indexada em 0 como C# ou C++, em vez de indexada em 1 como VB6.Isso significa que se você migrar para o VB.Net a partir de um idioma diferente, seus instintos de array provavelmente estarão errados, não importa qual seja o idioma.Em VB.Net, Dim arr(3,3) como inteiro na verdade cria um 4x4 variedade.

arr.GetLength(y)

deveria estar

arr.GetLength(1)

Bem, e se eu tivesse um array parecido com este

{ {1, 2, 3},
  {4, 5, 6, 7, 8, 9, 9, 9},
  {5, 4, 3, 2}
}

Como GetLength(1) ainda saberia o comprimento de cada linha?


Basicamente o que eu quero é.... uma maneira de encontrar o número de elementos em qualquer linha.

Dim arr(3, 3) As Integer
Dim y As Integer
Dim x As Integer

For x = 0 To arr.Rank - 1
    For y = 0 To arr.GetLength(x) - 2
        arr(x, y) = x + y
    Next
Next

O código acima funcionou para mim.

Editar, o código parece sujo.Estou me perguntando o que você está tentando realizar?

Este código em C# é para obter todas as combinações de itens em uma matriz irregular:

    static void Main(string[] args)
    {
        bool exit = false;
        int[] indices = new int[3] { 0, 0, 0 };
        string[][] vectores = new string[3][];

        vectores[0] = new string[] { "A", "B", "C" };
        vectores[1] = new string[] { "A", "B" };
        vectores[2] = new string[] { "B", "D", "E", "F" };

        string[] item;
        int[] tamaños = new int[3]{vectores[0].GetUpperBound(0), 
            vectores[1].GetUpperBound(0), 
            vectores[2].GetUpperBound(0)};

        while (!exit)
        {
            item = new string[]{ vectores[0][indices[0]],
                    vectores[1][indices[1]],
                    vectores[2][indices[2]]};

            Console.WriteLine("[{0},{1},{2}]={3}{4}{5}", indices[0], indices[1], indices[2], item[0], item[1], item[2]);
            GetVector(tamaños, ref indices, ref exit);
        }
        Console.ReadKey();
    }

    public static void GetVector(int[] tamaños, ref int[] indices, ref bool exit)
    {
        for (int i = tamaños.GetUpperBound(0); i >= 0; i--)
        {
            if (tamaños[i] > indices[i])
            {
                indices[i]++;
                break;
            }
            else
            {
                //ULTIMO ITEM EN EL ARRAY, VALIDAR LAS OTRAS DIMENSIONES SI YA ESTA EN EL ULTIMO ITEM
                if (!ValidateIndexes(tamaños, indices))
                    indices[i] = 0;
                else
                {
                    exit = true;
                    break;
                }
            }
        }
    }

    public static bool ValidateIndexes(int[] tamaños, int[] indices)
    {
        for (int i = 0; i < tamaños.Length; i++)
        {
            if (tamaños[i] != indices[i])
                return false;
        }
        return true;
    }

A saída parece [0,0,0] = AAB [0,0,1] = AAD [0,0,2] = AAE [0,0,3] = AAF [0,1,0] = ABB [ 0,1,1] = ABD [0,1,2] = ABE [0,1,3] = ABF [1,0,0] = BAB [1,0,1] = ruim [1,0,2 ] = BAE [1,0,3] = BAF [1,1,0] = BBB [1,1,1] = BBD [1,1,2] = BBE [1,1,3] = BBF [2 , 0,0] = CAB [2,0,1] = CAD [2,0,2] = CAE [2,0,3] = CAF [2,1,0] = CBB [2,1,1] = CBD [2,1,2] = CBE [2,1,3] = CBF

Sua declaração: DIM arr(3,3) As Integer já especifica que existem 3 elementos em qualquer linha (ou 4, não tenho tanta certeza sobre VB)

Você poderia tentar:

Dim arr(3) as Integer()

Você deverá então ser capaz de fazer:

arr(n).Length

Para encontrar o comprimento da linha n.

Estou um pouco enferrujado no VB6 e nunca aprendi VB.NET, mas isso deve fornecer um array 'irregular'.Confira a documentação do MSDN sobre arrays multidimensionados.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top