Ir ao conteúdo

Posts recomendados

Postado

Bom dia!

Seguinte, estou no primeiro período de Sistemas de Informação e como trabalho final do semestre o professor de Algoritmos e Técnicas de Programação pediu para fazer um aplicativo comercial em C. Aí acontece que houve um probleminha no meu programa, na parte de cadastro: 

senha[10] e confirmsenha[10] são strings e devem ter o mesmo valor.

porém, o seguinte código não está fazendo o que quero

 do

            {
                     printf("Digite sua senha: \n");
                scanf("%s", &senha);
                       printf("Confirme sua senha: \n");
                scanf("%s", &confirmsenha);
                 if (senha != confirmsenha)
                  {
                        printf("As senhas digitadas não correspondem \n");
                       }
                       fflush(stdin);
                  }while(senha != confirmsenha);

pois, mesmo senha e confirmsenha sendo inseridas pelo scanf a mesma coisa, Ex: C e C, o código repete;

Creio que é porque são vetores e armazenam dados nas lacunas vagas, aí sempre ficam diferentes...
Como corrijo isto?
Postado

 Opa beleza?

 

Você pode utilizar a biblioteca string.h

 

Exemplo

#include <stdio.h>#include <stdlib.h>#include <string.h> int main(){    char Senha[10], CSenha[10];    int ComparacaoStrings[100]; // Numero maximo de comparações     scanf(" %s", &Senha);    scanf(" %s", &CSenha);     int Resultado = strncmp(Senha, CSenha, ComparacaoStrings);     if(Resultado == 0){ // Resultado 0 significa que as strings são iguais        printf(" Senhas correspondem");    }else{        printf(" Senhas nao correspondem");    }     printf("\n");    system("pause");    return 0;}
Postado

@Lucas Fraga


Obrigado pela resposta Lucas, mas o código:

 

do	             {                          printf("Digite sua senha: \n");    	               scanf("%s", &senha);                          printf("Confirme sua senha: \n");    	               scanf("%s", &confirmsenha);    	               int resultadocomparacao = strncmp(senha, confirmsenha, comparacaostrings);                          if(resultadocomparacao == 0){ // Resultado 0 significa que as strings são iguais                              printf(" Senhas correspondem");                          }else{                              printf(" Senhas nao correspondem");                          }                  }while(resultadocomparacao != 0);

 
retornam os erros:
65 C:\Users\Home\Desktop\Atividade Final\atividade final.cpp invalid conversion from `int*' to `size_t' 
65 C:\Users\Home\Desktop\Atividade Final\atividade final.cpp   initializing argument 3 of `int strncmp(const char*, const char*, size_t)' 

 

Postado

@Lucas Fraga

Obrigado pela resposta Lucas, mas o código:

 

do	             {                          printf("Digite sua senha: \n");    	               scanf("%s", &senha);                          printf("Confirme sua senha: \n");    	               scanf("%s", &confirmsenha);    	               int resultadocomparacao = strncmp(senha, confirmsenha, comparacaostrings);                          if(resultadocomparacao == 0){ // Resultado 0 significa que as strings são iguais                              printf(" Senhas correspondem");                          }else{                              printf(" Senhas nao correspondem");                          }                  }while(resultadocomparacao != 0);

 

retornam os erros:

65 C:\Users\Home\Desktop\Atividade Final\atividade final.cpp invalid conversion from `int*' to `size_t' 

65 C:\Users\Home\Desktop\Atividade Final\atividade final.cpp   initializing argument 3 of `int strncmp(const char*, const char*, size_t)' 

 

 

Você adicionou a biblioteca ?

 

#include <string.h>
Postado

mudando 'comparacaostrings[100]' para 'comparacaostrings

int resultadocomparacao,comparacaostrings;char nomecompleto[30], email[20], senha[10], confirmsenha[10];do            {                          printf("Digite sua senha: \n");                    scanf("%s", &senha);                          printf("Confirme sua senha: \n");                    scanf("%s", &confirmsenha);                    int resultadocomparacao = strcmp(senha, confirmsenha, comparacaostrings);                          if(resultadocomparacao == 0){ // Resultado 0 significa que as strings são iguais                              printf(" Senhas correspondem");                          }else{                              printf(" Senhas nao correspondem");                          }                  }while(resultadocomparacao != 0);

continua a repetir o código mesmo com as senhas iguais;


Mudando strncmp para strcmp, também continua a repetir o código mesmo com senhas iguais...

 

Postado

...

do {

printf("Digite sua senha: \n");

scanf("%s", &senha);

printf("Confirme sua senha: \n");

scanf("%s", &confirmsenha);

resultadocomparacao = strcmp(senha, confirmsenha);

if(resultadocomparacao == 0){ // Resultado 0 significa que as strings são iguais

printf(" Senhas correspondem");

}else{

printf(" Senhas nao correspondem");

}

}while(resultadocomparacao);

Postado

O código fonte que lhe forneci funcionou corretamente em minha maquina, experimente dar um espaço para limpar buffer, assim.

 

 scanf("%s". &senha); // Antesscanf(" %s", &senha); // Depois 
Postado

Não é preciso usar & (E comercial) para jogar strings no vetor char.

   printf("Digite sua senha: \n");                scanf("%s", &senha); //Não precisa                       printf("Confirme sua senha: \n");                scanf("%s", &confirmsenha)//não precisa

Não se compara string como se compara um numero inteiro ou um flutuante

para comparar strings ja tem as funcoes pre definidas na biblioteca string.h

de manipulacao de string e a mais adequada para a sua necessidade seria strcmp 

 

 

 

Seu codigo ficaria assim:

#include <stdio.h>#include <stdlib.h>#include <string.h> int main(int argc, char *argv[]){    char Senha[125];    char CSenha[125];        	printf("\n\nDigite sua senha: ");    scanf(" %s", Senha);            printf("\n\nDigite sua Senha novamente: ");	scanf(" %s", CSenha);     if(strcmp(Senha, CSenha)==0){      // Resultado 0 significa que as strings são iguais        system("cls");      printf("\n\nSenhas correspondem");    		}else{		     system("cls");		 printf("\n\nSenhas nao correspondem");	}     printf("\n\n\n");    	getch();    return 0;}
Postado

@

Eu quero fazer um banco de dados com 100 senhas diferentes para 100 usuários diferentes, então se eu faço da maneira como disse:
 

printf("\n\nDigite sua senha: ");scanf(" %s", Senha);printf("\n\nDigite sua Senha novamente: ");    scanf(" %s", CSenha);if(strcmp(Senha, CSenha)==0){// Resultado 0 significa que as strings são iguaissystem("cls");printf("\n\nSenhas correspondem");        }else{         system("cls");         printf("\n\nSenhas nao correspondem");    }

acrescentando um for para verificar senha por senha na hora do acesso:
 

for (verif=0; verif<100; verif++)                         {                                   if(strcmp(senha[verif], senhaacesso==0)                                               {                                        resultadodesenha = 1;                                   }                                   else                                   {                                        resultadodesenha = 0;                                                    }                         }

Aparece o seguinte erro:
71 C:\Users\Home\Desktop\Atividade Final\atividade final.cpp cannot convert `bool' to `const char*' for argument `2' to `int strcmp(const char*, const char*)' 

Poderia me ajudar?

Desde já, obrigado

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

GRÁTIS: ebook Redes Wi-Fi – 2ª Edição

EBOOK GRÁTIS!

CLIQUE AQUI E BAIXE AGORA MESMO!