Ir ao conteúdo
  • Cadastre-se

Usuario entra com alfabeto, e o programa diz se a palavra existe no alfabeto


Guga Cracker

Posts recomendados

Implemente um programa em C onde:

 O usuário entra com um alfabeto, formado por uma quantidade de caracteres que o usuário desejar, em seguida o usuário entra com uma palavra e o programa verifica se esta palavra(combinação de caracteres) possui no alfabeto digitado anteriormente.

 

Minhas dificuldades são:

 - Fazer o tamanho do vetor ficar dinâmico(usuário que decide o tamanho do mesmo).

- Função para comparar a existência da palavra dentro do alfabeto digitado.

 

Segue até onde consegui efetuar o algoritmo!

 

 

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

int compara(char palavra, char vetor[]){
     int i=0;
     for(i; i < strlen(vetor); i++){
          if(palavra==vetor[i])
                return 1;
    }
    return 0;
}

void main()
{
	char alfabeto[5000], palavra[5000];
	
	printf("Digite o alfabeto: ");
	gets(alfabeto);
	
	printf("\nDigite a palavra do seu alfabeto: ");
	gets(palavra);
	
	if(compara(palavra, alfabeto)==1){
		printf("O caracter: %s possui no alfabeto: %s"), palavra, alfabeto;
		return;
	}
	
	printf("Esta palavra nao existe no alfabeto");
	return;
}

 

Link para o comentário
Compartilhar em outros sites

  • Moderador

Caro usuário,

 

Seja bem-vindo ao Fórum do Clube do Hardware.

 

No intuito de servir como fonte de pesquisa no caso de instituições de ensino, informamos que incorrer no resolvimento por completo de questões relacionadas a disciplinas escolares de cursos técnicos e faculdades podem ser revistas e removidas pela Equipe de Moderação do Clube do Hardware.

 

Para sanar dúvidas sobre esse tipo de problema, por gentileza, publique o passo a passo do desenvolvimento da questão, projeto, monografia ou conteúdo em dúvida para que possamos analisar se a resposta está correta ou não, ou para que possa ser auxiliado com a dúvida no desenvolvimento do exercício.

 

Infelizmente, não há como resolver os trabalhos pelos usuários. O objetivo do Fórum do Clube do Hardware é auxiliar seus usuários a encontrar soluções para que possam sanar suas dúvidas, e não de trazer soluções prontas para seus usuários.. Além disso, copiar e colar respostas que não são de autoria própria do qualquer usuário é considerado plágio, o que é ilegal.

 

Esperamos que compreenda.

 

Atenciosamente,

Equipe Clube do Hardware

Link para o comentário
Compartilhar em outros sites

Implemente um programa em C onde:

 O usuário entra com um alfabeto, formado por uma quantidade de caracteres que o usuário desejar, em seguida o usuário entra com uma palavra e o programa verifica se esta palavra(combinação de caracteres) possui no alfabeto digitado anteriormente.

 

Minhas dificuldades são:

 - Fazer o tamanho do vetor ficar dinâmico(usuário que decide o tamanho do mesmo).

- Função para comparar a existência da palavra dentro do alfabeto digitado.

 

Segue até onde consegui efetuar o algoritmo!

 

 

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

int compara(char palavra, char vetor[]){
     int i=0;
     for(i; i < strlen(vetor); i++){
          if(palavra==vetor[i])
                return 1;
    }
    return 0;
}

void main()
{
	char alfabeto[5000], palavra[5000];
	
	printf("Digite o alfabeto: ");
	gets(alfabeto);
	
	printf("\nDigite a palavra do seu alfabeto: ");
	gets(palavra);
	
	if(compara(palavra, alfabeto)==1){
		printf("O caracter: %s possui no alfabeto: %s"), palavra, alfabeto;
		return;
	}
	
	printf("Esta palavra nao existe no alfabeto");
	return;
}

 

Link para o comentário
Compartilhar em outros sites

Boa tarde, então, pouco depois de você postar eu ia responder mas travou o note kk, enfim, segue minhas dicas:

 1)Fazer o tamanho do vetor ficar dinâmico

usando malloc você pode alocar dinamicamente o tamanho do vetor, porém existem diversas formas de fazer isso, como:

 

char *alocar(int tam){
   return((char*)malloc(sizeof(char)*tam));
}

char *palavra = alocar(5);

 

A saída é de um vetor com o tamanho determinado na variável tam. Perceba que se a palavra for maior do que tam, é necessário determinar seu fim usando '\0' na ultima letra. x[tam] = '\0';

Essa é uma das formas, como você também pode fazer tudo isso no escopo da função main.

Também pode fazer a função acima, pedindo o tamanho para o usuário, ou criando uma string temporária, e usando o strlen para obter o tamanho a ser usado.

 

 2)Função para comparar a existência da palavra dentro do alfabeto digitado.

Vou esboçar bem rápido, 1 você tem um alfabeto com x de letras e 2 você tem uma palavra com y  de letras.

Usando uma função igual a de uma matriz, apenas mudando a letra da palavra/alfabeto é possível analisar todas letras:

 

// LOOP Y que seleciona letra da palavra

for(y = 0; y < tam_palavra; y++){

  // LOOP X que seleciona letra do alfabeto e compara com LOOP Y

  for(x =  0; x < tam_alfabaeto; x++){

   if(alfabeto[x] == palavra[y]) 

   ...

  }

}

 

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