Ir ao conteúdo

Posts recomendados

Postado

Desenvolva um programa que leia os valores de uma matriz de ordem 5 e verifique se ela é ou não uma
matriz triangular superior (matriz triangular superior é uma matriz onde todos os elementos de posições
acima da diagonal principal são diferentes de 0 e todos os elementos demais elementos são iguais a 0).

 

não to conseguindo acertar esse logica alguem me ajuda?

#include <stdio.h>
#include<time.h>
int main()
{
   int m[5][5],i,j;
srand(time(NULL));

   for(i=0;i<5;i++){
        printf("digite os numeros da linha: %d\n",i+1);
        for(j=0;j<5;j++){
        printf("coluna: %d\n",j+1);
            scanf("%d",&m[i][j]);
        }
    }

   for(i=0;i<5;i++){
        printf(" \n\n ");
        for(j=0;j<5;j++){
            printf(" %d ",m[i][j]);
        }
    }
   for(i=0;i<5;i++){
        for(j=0;j<5;j++){

        }
   if(m[i][j+1]>0){
            printf("\n\ntriangular superior\n\n");
        }
        else{
            printf("\n\nnao e triangular superior\n\n");
            }}
    return 0;
}

 

 

triangular superior.jpg

adicionado 13 minutos depois
#include <stdio.h>
#include<time.h>
int main()
{
   int m[5][5],i,j;
srand(time(NULL));

   for(i=0;i<5;i++){
        printf("digite os numeros da linha: %d\n",i+1);
        for(j=0;j<5;j++){
        printf("coluna: %d\n",j+1);
            scanf("%d",&m[i][j]);
        }
    }

   for(i=0;i<5;i++){
        printf(" \n\n ");
        for(j=0;j<5;j++){
            printf(" %d ",m[i][j]);
        }
    }
    int s = 10;
   for(i=0;i<5;i++){
        for(j=0;j<5;j++){

        }
   if(m[i][j+1]>0){
           s=0;
        }
        else{
            s=1;
            }
    }
    if(s=0){
    printf("\n\ntriangular superior\n\n");}
    if(s=1){
    printf("\n\nnao e triangular superior\n\n");}

    return 0;
}

:confused:

triangular superior1.jpg

  • Curtir 1
Postado

A única condição para uma matriz ser uma matriz triangular superior é que os números abaixo da diagonal principal sejam iguais a 0 (o que implica que uma matriz diagonal é tanto uma matriz triangular superior quanto inferior).

 

As casas da matriz abaixo da diagonal principal são as em que i > j (onde i é a coordenada da linha e j a coordenada da coluna da matriz).

 

Logo, a lógica algoritmo fica assim:

 

int triangularsuperior;

//Em C um valor diferente de 0 é VERDADEIRO
triangularsuperior = -1; 
for (i = 0; i < 5; ++i){
    for (j = 0; j < 5; ++j){
        if (i > j && matriz[i][j] != 0)
            triangularsuperior = 0; //0 = FALSO
    }    
}

if (triangularsuperior)
    printf("\nMATRIZ TRIANGULAR SUPERIOR\n");
else
    printf("\nNAO E UMA MATRIZ TRIANGULAR SUPERIOR\n");

 

  • Curtir 2
Visitante
Este tópico está impedido de receber novas respostas.

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...

Ebook grátis: Aprenda a ler resistores e capacitores!

EBOOK GRÁTIS!

CLIQUE AQUI E BAIXE AGORA MESMO!