Calculo de la letra del DNI en C
C/Visual C
Publicado el 15 de Marzo del 2002 por Josechu Marin Zaldivar (3 códigos)
11.866 visualizaciones desde el 15 de Marzo del 2002
Código que hace el cálculo del DNI. Realizado en C.
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
////////////////////////////////////PROTOTIPOS///////////////////////////////////////////
void introducir_datos(char *);
void tratar_datos (char *, char *);
char calcular_letra (int resto);
void visualizar_datos (char *, char letra);
////////////////////////////////////FUNCIONES///////////////////////////////////////////
void main(void)
{
char dni[8], letra;
int pos=0;
introducir_datos(&dni[0]);
tratar_datos (&dni[0], &letra);
visualizar_datos (&dni[0], letra);
}// end of main
void introducir_datos(char *dni)
{
int longitud;
do
{
printf ("\n\n Introduce el D.N.I. comprendido entre 100000 y 99999999\n");
gets(dni);
fflush(stdin);
longitud=strlen(dni);//asi sabemos el número de char de la cadena para validar
}
while (longitud<=5 || longitud>=9);
}// end of introducir_datos
void tratar_datos (char *dni, char *letra)
{
int dni_int, resto;
dni_int=atoi(dni);
resto=dni_int%23;
*letra=calcular_letra (resto);
}//end of tratar_datos
char calcular_letra (int r)
// funcion de tipo char que nos devuelve la letra del d.n.i.
{
char opcion;
switch (r)
{
case 0:
opcion= 'T';
break;
case 1:
opcion= 'R';
break;
case 2:
opcion='W';
break;
case 3:
opcion= 'A';
break;
case 4:
opcion= 'G';
break;
case 5:
opcion= 'M';
break;
case 6:
opcion= 'Y';
break;
case 7:
opcion= 'F';
break;
case 8:
opcion= 'P';
break;
case 9:
opcion= 'D';
break;
case 10:
opcion= 'X';
break;
case 11:
opcion= 'B';
break;
case 12:
opcion= 'N';
break;
case 13:
opcion= 'J';
break;
case 14:
opcion= 'Z';
break;
case 15:
opcion= 'S';
break;
case 16:
opcion= 'Q';
break;
case 17:
opcion= 'V';
break;
case 18:
opcion= 'H';
break;
case 19:
opcion= 'L';
break;
case 20:
opcion= 'C';
break;
case 21:
opcion= 'K';
break;
case 22:
opcion= 'E';
break;
}// end switch
return (opcion);
} //end of calcular_letra
void visualizar_datos (char *dni, char letra)
// utilizamos los 'for' para una presentación optima con separación de millares
{
char cadena[9];
int longitud, pos;
longitud=strlen(dni);
printf("\n");
switch (longitud)
{
case 6:
for (pos=0;pos<longitud;pos++)
{
printf("%c",dni[pos]);
if (pos==0) cadena[pos]=dni[pos];
if (pos==1) cadena[pos]=dni[pos];
if (pos==2) cadena[pos]=dni[pos];
if (pos==3) cadena[pos]='.';
if (pos==4) cadena[pos]=dni[pos-1];
if (pos==5) cadena[pos]=dni[pos-1];
if (pos==6) cadena[pos]=dni[pos-1];
if (pos==7) cadena[pos]=' ';
if (pos==8) cadena[pos]=letra;
}
break;
case 7:
for (pos=0;pos<longitud;pos++)
{
printf("%c",dni[pos]);
if (pos==0) printf(".");
if (pos==3) printf(".");
}
break;
case 8:
for (pos=0;pos<longitud;pos++)
{
printf("%c",dni[pos]);
if (pos==1) printf(".");
if (pos==4) printf(".");
}//end for
break;
} // end switch
printf(" %c\n\n",letra);
}// end visualizar_datos
Comentarios sobre la versión: Versión 1 (4)
Para empezar el algoritmo no esta enrevesado ya que esta estructurado en función de los datos que se tienen que obtener dentro del programa por eso se diseñan llamadas a funciones para que el programa esta estructurado.
Ya sé como en C se declaran las cadenas de caracteres que al final va '/0' pero como ya sabras estimado amigo Javi que los compiladores de hoy en día permiten hacer esa salvedad y en algoritmo funciona perfectamente.
Los arrays están pasados por referencia como bien sabes, no sé a que viene ese comentario, poniendo &dni[0], se indica la dirección de comienzo del array.
Por último te habras dado cuenta que el programa funciona a la perfección.
Sin más, un cordial saludo.