예제 #1
0
        private void btnInserir_Click(object sender, EventArgs e)
        {
            //Ele tenta converter os valores dos textboxes,
            //caso os campos não estejam preenchidos corretamente,
            //jogamos uma exceção informando o usuário
            try
            {
                double valor  = double.Parse(txtValor.Text.Trim());
                int    coluna = int.Parse(txtColuna.Text.Trim());
                int    linha  = int.Parse(txtLinha.Text.Trim());

                //Verifica em qual matriz o dado deverá ser inserido e, em seguida,
                //chama o método Inserir da classe MatrizEsparsa
                if (cbxMatrizInserir.SelectedItem.ToString() == "Matriz 1")
                {
                    try
                    {
                        matriz1.Inserir(new Celula(valor, linha, coluna, default(Celula), default(Celula)));
                        Exibir(dgvMatriz1, matriz1);
                    }
                    catch (Exception erro)
                    {
                        MessageBox.Show(erro.Message, "Operações com Matriz Esparsa | Erro de inserção", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    }
                }
                else
                {
                    try
                    {
                        matriz2.Inserir(new Celula(valor, linha, coluna, default(Celula), default(Celula)));
                        Exibir(dgvMatriz2, matriz2);
                    }
                    catch
                    {
                        MessageBox.Show("Linha ou coluna fora do intervalo", "Operações com Matriz Esparsa | Erro de inserção", MessageBoxButtons.OK, MessageBoxIcon.Information);
                    }
                }
            }
            catch
            {
                MessageBox.Show("Parâmetros não passados corretamente!", "Operações com Matriz Esparsa | Erro de inserção", MessageBoxButtons.OK, MessageBoxIcon.Information);
            }
        }
예제 #2
0
        public MatrizEsparsa SomarMatrizes(MatrizEsparsa matriz1, MatrizEsparsa matriz2)
        {
            MatrizEsparsa resultado;

            if (matriz1.NumeroLinhas == matriz2.NumeroLinhas && matriz1.NumeroColunas == matriz2.NumeroColunas)
            {
                resultado = new MatrizEsparsa(matriz1.NumeroLinhas, matriz1.NumeroColunas);

                Celula topo1  = matriz1.NoCabeca.Direita,
                       topo2  = matriz2.NoCabeca.Direita;
                Celula atual1 = topo1.Abaixo,
                       atual2 = topo2.Abaixo;
                while (topo1 != matriz1.NoCabeca && topo2 != matriz2.NoCabeca)
                {
                    if (atual1.Linha == atual2.Linha && atual1.Coluna == atual2.Coluna)
                    {
                        if (atual1.Valor + atual2.Valor != 0)
                        {
                            resultado.Inserir(new Celula(atual1.Valor + atual2.Valor, atual1.Linha, atual1.Coluna, default(Celula), default(Celula)));
                        }

                        atual1 = atual1.Abaixo;
                        atual2 = atual2.Abaixo;
                    }
                    else
                    if (atual1.Linha < atual2.Linha && atual1.Coluna == atual2.Coluna)
                    {
                        resultado.Inserir(new Celula(atual1.Valor, atual1.Linha, atual1.Coluna, default(Celula), default(Celula)));
                        atual1 = atual1.Abaixo;
                    }
                    else
                    if (atual2.Linha < atual1.Linha && atual2.Coluna == atual1.Coluna)
                    {
                        resultado.Inserir(new Celula(atual2.Valor, atual2.Linha, atual2.Coluna, default(Celula), default(Celula)));
                        atual2 = atual2.Abaixo;
                    }
                    else
                    if (atual1.Coluna != atual2.Coluna)
                    {
                        if (atual1.Coluna < atual2.Coluna)
                        {
                            resultado.Inserir(new Celula(atual1.Valor, atual1.Linha, atual1.Coluna, default(Celula), default(Celula)));
                            atual1 = atual1.Abaixo;
                        }
                        else
                        {
                            resultado.Inserir(new Celula(atual2.Valor, atual2.Linha, atual2.Coluna, default(Celula), default(Celula)));
                            atual2 = atual2.Abaixo;
                        }
                    }
                    while (atual1 == topo1)
                    {
                        topo1  = topo1.Direita;
                        atual1 = topo1.Abaixo;
                    }
                    while (atual2 == topo2)
                    {
                        topo2  = topo2.Direita;
                        atual2 = topo2.Abaixo;
                    }
                }
                while (topo1 != matriz1.NoCabeca)
                {
                    resultado.Inserir(new Celula(atual1.Valor, atual1.Linha, atual1.Coluna, default(Celula), default(Celula)));
                    atual1 = atual1.Abaixo;
                    if (atual1 == topo1)
                    {
                        topo1  = topo1.Direita;
                        atual1 = topo1.Abaixo;
                    }
                }
                while (topo2 != matriz2.NoCabeca)
                {
                    resultado.Inserir(new Celula(atual2.Valor, atual2.Linha, atual2.Coluna, default(Celula), default(Celula)));
                    atual2 = atual2.Abaixo;
                    if (atual2 == topo2)
                    {
                        topo2  = topo2.Direita;
                        atual2 = topo2.Abaixo;
                    }
                }
            }
            else
            {
                throw new Exception("Matrizes com dimensões diferentes não podem ser somadas!");
            }

            return(resultado);
        }
예제 #3
0
        public MatrizEsparsa MultiplicarMatrizes(MatrizEsparsa matriz1, MatrizEsparsa matriz2)
        {
            MatrizEsparsa resultado;

            //Verifica se as matrizes estão em condições ideias para efetuar a multiplicação
            if (matriz1.NumeroColunas == matriz2.NumeroLinhas && matriz1 != null && matriz2 != null)
            {
                //Geramos uma terceira matriz para armazenar o resultado da multiplicação
                resultado = new MatrizEsparsa(matriz1.NumeroLinhas, matriz2.NumeroColunas);

                //Variável para armazenar a soma dos elementos multiplicados
                //que serão dispostos em uma célula da matriz resultante
                double valorCelulaAInserir = 0;

                //Índice auxiliar que percorrerá tanto as colunas da matriz1,
                //quanto as linhas da matriz2
                int quantoPercorrer = matriz1.NumeroColunas;

                //Percorre uma linha da matriz resultante
                for (int linha = 1; linha <= resultado.NumeroLinhas; linha++)
                {
                    //Percorre uma linha da matriz resultante
                    for (int coluna = 1; coluna <= resultado.NumeroColunas; coluna++)
                    {
                        //Percorre uma coluna da matriz1 e uma linha da matriz2 em paralelo
                        for (int indice = 1; indice <= quantoPercorrer; indice++)
                        {
                            //Caso o objeto retornado seja nulo, isso significado
                            //que o valor da célula é zero
                            if (matriz1.Procurar(indice, linha) == default(Celula))
                            {
                                if (matriz2.Procurar(coluna, indice) == default(Celula))
                                {
                                    valorCelulaAInserir += 0;
                                }
                                else
                                {
                                    valorCelulaAInserir += 0 * matriz2.Procurar(coluna, indice).Valor;
                                }
                            }
                            else
                            if (matriz2.Procurar(coluna, indice) == default(Celula))
                            {
                                valorCelulaAInserir += matriz1.Procurar(indice, linha).Valor * 0;
                            }
                            else
                            {
                                valorCelulaAInserir += matriz1.Procurar(indice, linha).Valor *matriz2.Procurar(coluna, indice).Valor;
                            }
                        }
                        //Após efetuar a multiplicação, inserimos o a somatória das multiplicações
                        //na linha e coluna atual, caso ele seja diferente de zero, pois não há
                        //necessidade de armazenar o zero
                        if (valorCelulaAInserir != 0)
                        {
                            resultado.Inserir(new Celula(valorCelulaAInserir, linha, coluna, null, null));
                        }
                        //reiniciamos a variável que armazena a somatória das multiplicações
                        valorCelulaAInserir = 0;
                    }
                }
            }
            else
            {
                throw new Exception("O número de colunas da matriz A não corresponde ao número de linhas da matriz B!");
            }

            return(resultado);
        }
예제 #4
0
        public void LerArquivo(ref MatrizEsparsa qualMatriz, StreamReader arquivo)
        {
            if (!arquivo.EndOfStream)
            {
                int    posX  = 0;
                string linha = arquivo.ReadLine();
                // for para descobrir as proporções da matriz
                for (int i = 0; i < linha.Trim().Length; i++)
                {
                    if (linha[i] == 'x')
                    {
                        posX = i;
                        break; // interrompe o for quando o 'x' for encontrado
                    }
                }
                // define as proporções das matrizes
                qualMatriz = new MatrizEsparsa(int.Parse(linha.Substring(posX + 1).Trim()),
                                               int.Parse(linha.Substring(0, posX)));
                int primeiraSeparacao = 0;
                int segundaSeparacao  = 0;
                // while para pegar os dados
                while (!arquivo.EndOfStream)
                {
                    linha = arquivo.ReadLine();
                    //for para identificar as separações, para que seja possível
                    //quebrar a string linha em "valor, coluna e linha"
                    for (int i = 0; i < linha.Trim().Length; i++)
                    {
                        if (linha[i] == ';')
                        {
                            //se a primeiraSeparacao já foi encontrada,
                            //segundaSeparacao receberá o índice onde foi encontrado
                            //o ponto e vírgula, senão a primeiraSeparação receberá esse índice
                            if (primeiraSeparacao != 0)
                            {
                                segundaSeparacao = i;
                            }
                            else
                            {
                                primeiraSeparacao = i;
                            }
                        }
                    }

                    //estabelecemos variáveis auxiliares para encurtar os parâmetros para a criação
                    //de um objeto da classe Celula
                    int    colunaDado = int.Parse(linha.Substring(0, primeiraSeparacao));
                    int    linhaDado  = int.Parse(linha.Substring(primeiraSeparacao + 1, segundaSeparacao - (primeiraSeparacao + 1)));
                    double valorDado  = double.Parse(linha.Substring(segundaSeparacao + 1).Trim());

                    //insere a célula lida na matriz
                    Celula celulaAtual = new Celula(valorDado, linhaDado, colunaDado, default(Celula), default(Celula));
                    if (linhaDado > qualMatriz.NumeroLinhas || colunaDado > qualMatriz.NumeroColunas)
                    {
                        throw new Exception("Célula fora das dimensões da Matriz!");
                    }
                    else
                    {
                        qualMatriz.Inserir(celulaAtual);
                    }
                }
                arquivo.Close();
            }
        }