Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

  • 0
Silva Mateus

Struct em C

Pergunta

Olá, tenho dois problemas que são o seguinte: 
1 - Quando escolho a opção "1" e entro no cadastro de produtos o programa pula a etapa de cadastro do "nome", isto é , me deixando cadastrar somente o "codigo" e "estoque minimo". Me disseram que o FFLUSH resolveria esse problema, esse é realmente o método correto? 

2 - Quando vou na opção "2 - listar" ele não exibe os valores que foram cadastrado, isto é , a tabela é impressa corretamente só que os valores não são correspondentes. 
 

#include<stdio.h>
#include<strings.h>
#include<string.h>

#define max = 10;

int contador=0 ;


//ESTRUTURA DOS DADOS
struct produtos{
    int codigo;
    char nome[30];
    float precoMedioUnitario;
    int quantEstoque;
    int estoqueMinimo;
};

struct produtos cadProduto[9]; 

main(){
	
	menu();
   

}
// PROCEDIMENTO - VOID MENU 
void menu(){
	 // VARIAVEL PARA ESCOLHA SWITCH
    int escolha;


    // MENU
    printf("1 - Cadastrar um produto");
    printf("\n2 - Listar os produtos cadastrados");
    printf("\n3 - Consultar os dados de um produto ");
    printf("\n4 - Processar uma saida de mercadoria do estoque");
    printf("\n5 - Processar uma entrada de mercadoria no estoque");
    printf("\n6 - Sair do programa");
    //ESCOLHA DE OPERACAO
    printf("\nOperacao: ");
    scanf("%d", &escolha);

    //DESVIO PARA A OPCAO
    switch(escolha){
        case 1:
			cadastro();
        break;
        case 2:
			listar();
        break;
        case 3:

        break;
        case 4:

        break;
        case 5:

        break;
        case 6:

        break;

        default:
                printf("Valor Invalido");

    }
	}

// FUNCAO CADASTRO DE PRODUTOS
void cadastro(){
	
	int resultado; 
	do{
		//FORMULARIO DE CADASTRO 
		printf("Codigo do produto: ");
		scanf("%d", &cadProduto[contador].codigo);
		printf("\n");
		

		printf("Nome do produto: "); 
		fgets(cadProduto[contador].nome, 30, stdin);
		printf("\n");
		
		printf("Estoque minimo: "); 
		scanf("%d", &cadProduto[contador].estoqueMinimo);
		printf("\n");
		
		contador++; 
		
		
		
		printf("Deseja cadastrar mais produtos? Precione 1 - Sim ou 2 - Nao:\n");
		scanf("%d", &resultado); 
		while(resultado!=1 && resultado!=2){
			printf("\n");
			printf("Opcao invalida!"); 
			printf("\n"); 
			
			printf("Deseja cadastrar mais produtos? Precione 1 - Sim ou 2 - Nao:\n");
			scanf("%d", &resultado);
			
			
			}
		
		
		
		} while(resultado!=2);
	
	
	printf("\nOperacao Concluida com sucesso!\n"); 
	printf("\n");
	
	menu();
	
	}
	
	
void listar(){
		printf("\n");
	for(int i=0; i<contador;i++){
		printf("%d  | %c       | %d   | %f   | %d\n    ",cadProduto[contador].codigo,
		cadProduto[contador].nome, cadProduto[contador].quantEstoque, 
		cadProduto[contador].precoMedioUnitario, cadProduto[contador].estoqueMinimo
		
		);
		}
	
	
	}	

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

2 respostas a esta questão

Recommended Posts

Não. Não se faz flush na entrada padrão.

 

Os problemas com seu código:
1- Seu define está errado

2- Função main sem retorno

3- Teoricamente a função menu faz mais do que deveria (além de apresentar a opção, ela lê e se preocupa com a lógica de dispatch das chamadas às demais funções)
4- Cada vez que você chama uma função, a pilha de chamadas cresce. Então, imaginando que esse programa pudesse estar usando alocação dinâmica ao invés de estática, e esse menu seria chamado indefinidamente dentro do menu de cadastro, uma hora daria stack overflow ou algum erro dizendo que você tentou escrever em espaço proibido em memória.

5- A indexação está errada na listagem.

6- O formato no printf p/ o nome está errado (o nome é uma string, não um caractere)


Não existe a palavra "precionar" em português. Escreve-se "pressionar".

 

#include <stdio.h>
#include <string.h>
#define SIM 1
#define NAO 2
#define MAXPRODUTOS 10

#define CADASTRO 1
#define LISTAGEM 2
#define SAIR 6

struct produto{
    int codigo;
    char nome[30];
    float precoMedioUnitario;
    int quantEstoque;
    int estoqueMinimo;
};

struct produto cadProduto[MAXPRODUTOS]; 
int contadorProdutos = 0;


void menuPrincipal();
void leituraCadastro();
int confirmacaoContinuarCadastro();
void listarProdutos();

int main(void){
	int opcaoPrincipal;
	int opcaoConfirmarContinucao;
	
	while (1) {
    	menuPrincipal();
    	scanf("%d", &opcaoPrincipal);
    	
    	if (opcaoPrincipal == SAIR) break;
    	
    	switch(opcaoPrincipal){
            case CADASTRO:
                if (contadorProdutos == MAXPRODUTOS) {
                    puts("Não é possível cadastrar mais produtos.");
                } else {
                    do {
        			    leituraCadastro();
        			    opcaoConfirmarContinucao = confirmacaoContinuarCadastro();
                    } while (opcaoConfirmarContinucao == SIM && contadorProdutos < MAXPRODUTOS);
                }
                break;
            case LISTAGEM:
                if(contadorProdutos == 0) {
                    puts("Não há produtos cadastrados.");
                } else {
    			    listarProdutos();
                }
                break;
            default:
                printf("Valor Invalido");
    
        }
	}
    return 0;
}

void menuPrincipal(){
    printf("1 - Cadastrar um produto");
    printf("\n2 - Listar os produtos cadastrados");
    printf("\n3 - Consultar os dados de um produto ");
    printf("\n4 - Processar uma saida de mercadoria do estoque");
    printf("\n5 - Processar uma entrada de mercadoria no estoque");
    printf("\n6 - Sair do programa");
    printf("\nOpção: ");
}


void leituraCadastro(){
	printf("Codigo do produto: ");
	scanf("%d%*c", &cadProduto[contadorProdutos].codigo);
	printf("\n");
	

	printf("Nome do produto: "); 
	fgets(cadProduto[contadorProdutos].nome, 30, stdin);
	char * linebreak = strrchr(cadProduto[contadorProdutos].nome, '\n');
	(*linebreak) = '\0';
	printf("\n");
	
	printf("Estoque minimo: "); 
	scanf("%d%*c", &cadProduto[contadorProdutos].estoqueMinimo);
	printf("\n");
	
	contadorProdutos++; 
}

int confirmacaoContinuarCadastro() {
    int opcao;
    do {
        printf("Deseja cadastrar mais produtos? Pressione 1 - Sim ou 2 - Não:");
    	scanf("%d", &opcao); 
		if (opcao != SIM && opcao != NAO) {
		    puts("Opção inválida.");
		}
    
    } while(opcao != SIM && opcao != NAO);
    
    return opcao;
}
	
void listarProdutos(){
	for(int i=0; i<contadorProdutos;i++){
		printf("%d  | %s       | %d   | %f   | %d\n    ",
		        cadProduto[i].codigo,
		        cadProduto[i].nome, 
		        cadProduto[i].quantEstoque, 
		        cadProduto[i].precoMedioUnitario, 
		        cadProduto[i].estoqueMinimo
		);
	}
}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por mr22robot
      Ola caros amigos. 
      Estou com uma dúvida aqui que embora nao tenho achado ainda uma resposta, acredito que haja.
      Estou estudando a tão sonhada linguagem de programação asp.net core mvc. Linguagem essa que demorei 5 anos pra iniciar os estudos rsrs.
      Mas estou agarrado em uma situação. 
      Estou usando como base de dados nos meus estudos um banco Oracle. Que já tem algumas informações nele. Utilizei o SCAFFOLD para criar as classes e o contexto baseado no banco e tabelas existentes. 
      Porem agora na fase das consultas, estou perdido em como utilizar o IN que eu utilizo no oracle; no LINQ.
      Ex: 
      SELECT CODPROD,DESCRICAO FROM PRODUTO WHERE CODPROD IN(1,2,3,4,5,6) Como eu utilizo esse filtro com uma restrição de códigos de produtos? no caso o where codprod in(1,2,3,4,5,6) ?.
      Desde já obrigado pela ajuda.
    • Por luis0101010
      1.      Programe uma função que recebe um número inteiro e verifica se todos os dígitos deste número são iguais ou diferente e liste eles em ordens crescentes.
      Obs: Código fonte com no mínimo de 10 dígitos.
       
      Como exemplo, os números 456, −235, e 5 satisfazem esta condição, enquanto que o número 6 não.
       
      2.      Crie também a função main que recebe o valor do número digitado pelo usuário e exibe na tela uma mensagem informando se os dígitos deste número são iguais.
       
      Exemplo:
      --Exemplo 1:
      Informe um número:
      -555
      Numero informado possui todos os dígitos iguais
      --Exemplo 2:
      Informe um número:
      67
      Número informado não possui todos os dígitos iguais
    • Por TheLord23
      ESTOU COMEÇANDO AGORA NA PROGRAMAÇÃO COM VISUALG E TERIA QUE COLOCAR ESTE CODIGO EM UM LAÇO DE REPETIÇÃO.
      POREM NÃO ESTOU CONSEGUINDO PODERIAM ME AJUDAR ?
       
      SÓ PENSANDO QUE O USUÁRIO IRA DIGITAR O TAMANHO DO VETOR, APOS ISSO CADA OPÇÃO QUE ELE ESCOLHER E ELA SER EXECUTADA DE FORMA CORRETA ELE VOLTARA PARA O MEUNU PRINCIPAL DAS OPÇÕES ATE QUE ELE SELECIONE A OPÇÃO "F"
       
      POREM TENTEI ESCREVELO USANDO ENQUANTO MAS ACABOU QUE EU NÃO CONSIGO PREVINIR OS ERROS DO USUÁRIO QUANDO ELE COLOCA AS INFORMAÇÕES
       
      TIPO:
      -ARMAZENAR UM NÚMERO NO VETOR E ESSE NÚMERO NÃO SER SOBRESCREVIDO ATE QUE O PROGRAMA SEJA ENCERRADO
      -SE ELE DIGITAR PRA BUSCAR OU INSERIR O NÚMERO ZERO O PROGRAMA INFORMAR QUE O VALOR É INVÁLIDO
       
      TENTEI USAR PROCEDIMENTOS E FUNÇÕES MAS OS ERROS CONTINUARAM.
       
       
       
      Algoritmo "DESAFIO"
      Var
         AUX,CONTADOR,BUSCAR:INTEIRO
         POSICAO,AUX_TEMP:INTEIRO
         OPCAO:CARACTERE
         RESULT_BUSCA: LOGICO
         SOMA_VET:REAL
         NUMERO:VETOR[1..500]DE INTEIRO
      Inicio
         ESCREVAL("*********************************")
         ESCREVAL("* CADASTRO DE VETORES - DESAFIO *")
         ESCREVAL("*********************************")
         ESCREVA("DIGITE O TAMANHO DO VETOR A SER CADASTRADO: ")
         LEIA(AUX)
         NUMERO[AUX] <- AUX
         ESCREVAL("A - Cadastrar um novo número;")
         ESCREVAL("B - Buscar um número")
         ESCREVAL("C - Excluir um número;")
         ESCREVAL("D - Listar os números cadastrados;")
         ESCREVAL("E - Exibir a soma dos números do vetor;")
         ESCREVAL("F - Sair do sistema.")
         LEIA(OPCAO)
         OPCAO <- MAIUSC(OPCAO)
         ESCOLHA OPCAO
         CASO "A"
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               ESCREVA("DIGITE O VALOR QUE SERÁ ARMAZENADO NA",CONTADOR,"ª POSIÇÃO DO VETOR: ")
               LEIA(NUMERO[CONTADOR])
            FIMPARA
         CASO "B"
            ESCREVA("QUAL NÚMERO DESEJA ENCONTRAR: ")
            LEIA(BUSCAR)
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               SE NUMERO[CONTADOR] = BUSCAR ENTAO
                  RESULT_BUSCA <- VERDADEIRO
                  POSICAO <- CONTADOR
               FIMSE
            FIMPARA
            PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
               ESCREVAL(NUMERO[CONTADOR])
            FIMPARA
            ESCREVAL("")
            ESCREVAL("---------")
            SE RESULT_BUSCA = VERDADEIRO ENTAO
               ESCREVAL("O NÚMERO",BUSCAR,"FOI ENCONTRADO E ESTA NA POSIÇÃO",POSICAO)
            SENAO
               ESCREVAL("O NÚMERO NÃO FOI ENCONTRADO !")
            FIMSE
         CASO "C"
            escreval("QUAL NÚMERO DESEJA EXCLUIR DO VETOR: ")
            leia(BUSCAR)
            SE NUMERO[CONTADOR] = BUSCAR ENTAO
               NUMERO[CONTADOR] <- 0
               ESCREVAL("O NÚMERO",BUSCAR,"NA POSIÇÃO",POSICAO,"DO VETOR FOI EXCLUIDO !")
            FIMSE
            PARA CONTADOR DE 1 ATE NUMERO[AUX]
               PARA AUX DE CONTADOR + 1 ATE AUX FACA
                  SE NUMERO[AUX] > NUMERO[CONTADOR]
                     AUX_TEMP <- NUMERO[AUX]
                     NUMERO[AUX] <- NUMERO[CONTADOR]
                     NUMERO[CONTADOR] <- AUX_TEMP
                  FIMPARA
               FIMPARA
               ESCREVA("VALROES DO VETOR: ")
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  ESCREVAL(NUMERO[CONTADOR])
               FIMPARA
            CASO "D"
               ESCREVA("VALORES DO VETOR: ")
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  ESCREVAL(NUMERO[CONTADOR])
               FIMPARA
            CASO "E"
               PARA CONTADOR DE 1 ATE NUMERO[AUX] FACA
                  SOMA_VET <- SOMA_VET + NUMERO[CONTADOR]]
               FIMPARA
               ESCREVAL("")
               ESCREVA("A SOMA DO VETOR É:",SOMA_VET)
               
            CASO "F"
               ESCREVAL("ENCERRANDO SISTEMA...")
            OUTROCASO
               ESCREVAL("OPÇÃO INVÁLIDA !")
            FIMESCOLHA
      Fimalgoritmo
    • Por thiago_tw
      eu to com uma tarefa que preciso de ajuda, já tentei alguns algoritmos que achei por aqui mas nunca dá certo, mandei a imagem do que é para ser feito, agradecido se me ajudarem

    • Por Air-Gear
      Olá pessoal!
       
      Entregaram um código já montando e eu preciso fazer uma modificação na parte do campo url, já que ele é uma array de string com tamanho variado. Antes de mexer no código, já funcionava, mas o campo url pegava só a primeira posição. No Front-End que utiliza Javascript eu conseguir resolver, o Back-End que utiliza C# estou pegando agora. Eu implementei um foreach primeiro, mas vi que com for ficou melhor pra montar o código. Visual Studio não deu erro no código, mas não executou como devia. Eu tentei colocar "url = end;", mas apontou erro. Eu estou mais ou menos no caminho. Alguém pode me ajudar?
       
      Segue o código.
      public class clUpload { #region insert internal static bool novoUpload(tbUploadSCP obj) { tbUploadSCP uploadA = new tbUploadSCP(); using (TransactionScope ts = new TransactionScope()) { using (Repository<tbUploadSCP> repSol = new Repositoryupload()) { string[] end = { }; for (int i = 0; i < obj.url.Length; i++) { end[i] = obj.url[i].ToString(); obj.url = end[i]; } uploadA = new tbUploadSCP { url = obj.url, userId = obj.userId, upIdAcao = obj.upIdAcao, upTipo = obj.upTipo, upData = obj.upData, }; repSol.Add(uploadA); //var upMetaPeriodo = UpMetaPeriodo(obj); } ts.Complete(); return true; } } //Resto do código que não tem haver com o problema }  
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.