Ir ao conteúdo
  • Cadastre-se

C To bem confusa ainda com vetores, alguém pode me dizer onde to errando? 


drimorais35

Posts recomendados

Elabore um algoritmo que, dados dois vetores inteiros de 20 posições fornecidos pelo usuário, efetue as respectivas operações indicadas por um outro vetor de 20 posições de caracteres também fornecido pelo usuário, contendo as quatro operações aritméticas em qualquer combinação, armazenando os resultados em um quarto vetor.

 

#include <stdio.h>
#define N 2
int main()
{
    int VETOR1 [N], VETOR2 [N], i;
    float RESPOSTA [N];
    char OPERACAO [N];
    
    for (i = 0; i < N; i++)
   {
   printf("Entre com Vetor 1\n");
   scanf("%i",&VETOR1);
   }
   
   for (i = 0; i < N; i++)
   {
   printf("Entre com Vetor 2\n");
   scanf("%i",&VETOR2);
   }
   
   for (i = 0; i < N; i++)
   {
   printf("Escolha a Operação\n");
   scanf("%c",&OPERACAO);
   switch (OPERACAO)
   {
        case '+': RESPOSTA= VETOR2 + VETOR1;
        break;
        case '-': RESPOSTA= VETOR2 - VETOR1;
        break;
        case '*': RESPOSTA= VETOR2 * VETOR1;
        break;
        case '/':
        if (VETOR1 != 0)
        {
            RESPOSTA= VETOR2 / VETOR1;
        }
        else
        {
            printf("NAO EXISTE");
        }
        break;
        
        
   }
    
      printf("VETOR 1 é:%.0i\n",VETOR1);
      printf("VETOR 2 é:%.0i\n",VETOR2);
      printf("RESPOSTA é:%.0f\n",RESPOSTA);
}
return 0;
}

 

  • Obrigado 1
Link para o comentário
Compartilhar em outros sites

@drimorais35    para postar seu código é melhor usar o botão   <>   que está lá na barra de ferramentas da janela de responder pois senão seu código fica faltando alguns caracteres como os  [ i ]  que sumiram do seu código ,        seu código está certo só tem um erro ali no switch pois ele não funciona com string apenas com um caractere , então seu código seria assim  :

#include <stdio.h>
#define N 2
int main(){
    int VETOR1[N],VETOR2[N],i;
    float RESPOSTA[N];
    char OPERACAO;
    for (i=0;i<N;i++){
        printf("Entre com O %d Valor Do Vetor 1 ",i+1);
        scanf("%i",&VETOR1[i]);
    }
   for (i = 0; i < N; i++){
        printf("Entre com O %d Valor Do Vetor 2 ",i+1);
        scanf("%i",&VETOR2[i]);
    }
    for (i=0;i<N;i++){
        printf("Escolha a Operação     +  -  *  / ");
        fflush(stdin);
        scanf("%c",&OPERACAO);
        switch(OPERACAO){
        case '+':
            RESPOSTA[0]= VETOR2[i] + VETOR1[i];
            break;
        case '-':
            RESPOSTA[0]= VETOR2[i] - VETOR1[i];
            break;
        case '*':
            RESPOSTA[0]= VETOR2[i] * VETOR1[i];
            break;
        case '/':
            if (VETOR1[i] != 0){
                RESPOSTA[0]= VETOR2[i] / VETOR1[i];
            }
            else{
                printf("NAO EXISTE");
            }
            break;
        }
        printf("VETOR 1  eh -- : %  i\n",VETOR1[i]  );
        printf("VETOR 2  eh -- : %  i\n",VETOR2[i]  );
        printf("RESPOSTA eh -- : %.2f\n",RESPOSTA[0]);
    }
    return 0;
}

 

  • Amei 1
Link para o comentário
Compartilhar em outros sites

@devair1010 Olá. De acordo com o enunciado os vetores devem ter 20 posições. E também de acordo com o enunciado são necessários 4 vetores, dois de números inteiros fornecidos pelo usuário, outro vetor d char  para as operações e um quarto vetor para armazenar os resultados.

Logo, eu arriscaria dizer q o código fica dessa forma:

 

#include <stdio.h>

#define N 20

void limpa_linha() {
    scanf("%*[^\n]");
    scanf("%*c");
}

int main(){
    
    int VETOR1[N],VETOR2[N],i;
    float RESPOSTA[N];
    char OPERACAO[N];
    for (i=0;i<N;i++){
        printf("Entre com O %d Valor Do Vetor 1 ", i + 1);
        scanf("%i",&VETOR1[i]);
        limpa_linha();
    }
    for (i = 0; i < N; i++){
        printf("Entre com O %d Valor Do Vetor 2 ", i + 1);
        scanf("%i",&VETOR2[i]);
        limpa_linha();
    }
    for (i = 0; i < N; i++){
        printf("Escolha a Operacao     +  -  *  / ");
        scanf("%c", &OPERACAO[i]);
        limpa_linha();

        switch (OPERACAO[i]){
        case '+':
            RESPOSTA[i] = (float) VETOR1[i] + VETOR2[i];
            break;
        case '-':
            RESPOSTA[i] = (float) VETOR1[i] - VETOR2[i];
            break;
        case '*':
            RESPOSTA[i] = (float) VETOR1[i] * VETOR2[i];
            break;
        case '/':
            if (VETOR1[i] != 0 && VETOR2[i] != 0){
                RESPOSTA[i] = (float) VETOR1[i] / VETOR2[i];
            }
            else{
                printf("\nNAO EXISTE\n\n");
                continue;
            }
            break;
        }
        printf("VETOR 1  eh -- : %  i\n", VETOR1[i]);
        printf("VETOR 2  eh -- : %  i\n", VETOR2[i]);
        printf("RESPOSTA eh -- : %.2f\n",RESPOSTA[i]);
    }
    return 0;
}

Estou fazendo um casting explícito para q as operações sejam devidamente convertidas para o tipo de dado float

adicionado 8 minutos depois

Dá uma conferida para ver se é isso mesmo

Link para o comentário
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

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...