Foro de elhacker.net

Programación => Programación C/C++ => Mensaje iniciado por: BardoArmas en 24 Noviembre 2018, 05:46 am



Título: Ordenamiento de nombres en C#
Publicado por: BardoArmas en 24 Noviembre 2018, 05:46 am
Estoy trabajando en un programa en el cual se registran alumnos.
Tengo una opción que se trata en ordenar el nombre pero lo que debo verificar al ordenar el nombre es
1.-el apellido paterno y si el apellido paterno es igual al de otro alumno debo ahora verificar su apellido materno y si el otro alumno tiene el apellido paterno y materno igual ahora debo verificar el nombre.

Me podrían ayudar a resolverlo? 😅
Se lo agradecería mucho


Título: Re: Ordenamiento de nombres en C#
Publicado por: K-YreX en 24 Noviembre 2018, 06:05 am
Manda el código para ver cómo estás almacenando los alumnos, para ver si son estructuras, arrays...

De todas formas es simple, comparas un apellido con otro y si uno es menor, ese va primero y si son iguales, comparas el otro.


Título: Re: Ordenamiento de nombres en C#
Publicado por: BardoArmas en 24 Noviembre 2018, 06:27 am

#include <stdio.h>
#include <string.h>
#include <ctype.h>
#define max 50
typedef struct{
              char nombre[20];
              char apellidop[20];
              char apellidom[20];
}Alum;

typedef struct{
               int matricula;
              Alum alum;
              float dep[3];
              int edad;
              char sexo;
              float prom;
}Datos;

void guardar(Datos datos[max],int *conta);
void abrir(Datos datos[max],int *conta);
void modi_nombre(Datos datos[max],int *conta);
void modi_cal(Datos datos[max],int *conta);
void modi_edad(Datos datos[max],int *conta);
void modi_sexo(Datos datos[max],int *conta);
void modificar(Datos datos[max],int *conta);
void registro(Datos datos[max],int *conta);
void eliminar(Datos datos[max],int *conta);
void lista_a(Datos datos[max],int *conta);
void lista_r(Datos datos[max],int *conta);
void busqueda(Datos datos[max],int *conta);
void ordena(Datos datos[max],int *conta);
void prom(Datos datos[max],int *conta);
void consulta(Datos datos[max],int *conta);
void todos(Datos datos[max],int *conta);

//modulo principal indica todas las acciones principales a realizar
int main()
{
  int op, conta,res;
   Datos datos[max];
do {
    printf("\nPrograma que manipula lista de alumnos\n");
    printf("***************************************************\n");
    printf("seleccione la accion a realizar\n");
    printf("0.-Abrir un archivo\n");
    printf("1.-Registrar alumno\n");
    printf("2.-Modificar alumno\n");
    printf("3.-Eliminar un alumno\n");
    printf("4.-Consulta\n");
    printf("5.-Ordenar\n");
    printf("6.-Guardar archivo\n");
    printf("7.-Salir\n");
    scanf("%d",&op);
    switch (op) {
     case 0:
     printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
     printf("Usted selecciono abrir un archivo\n");
      abrir(datos,&conta);
           break;
      case 1:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono registrar un alumno\n");
      registro(datos,&conta);
              break;
      case 2:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono modificar datos de un alumno");
      modificar(datos,&conta);
           break;
      case 3:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono eliminar un alumnoo\n");
      eliminar(datos,&conta);
              break;
      case 4:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono consultar datos de los alumnos\n");
      consulta(datos,&conta);
              break;
      case 5:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono ordenar alumnos\n");
      ordena(datos,&conta);
              break;
      case 6:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono guardar un archivo\n");
      guardar(datos,&conta);
           break;
      case 7:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("selecciono salir\n");
      break;

      default:
      printf("Error proporcione una opcion valida\n");
    }
  }while (op!=7);
  do{
  printf("¿Desea guardar el archivo antes de salir?\n");
  printf("SI=1,NO=0\n");
  scanf("%d",&res);
   if (res!=1 && res!=0)
      printf("Error proporcione una opcion valida\n");
   if(res==1)
      guardar(datos,&conta);
   }while(res!=1 && res!=0);
  printf("Gracias por usar el Programa\n");
  return 0;
}

void abrir(Datos datos[max],int *conta)
{ char N[50];
   FILE *archivo;
   printf("Proporcione el nombre del archivo\n");
   scanf("%s",N);
   getchar();
   strcat(N,".dat");
   archivo=fopen(N,"rb");
     if(archivo==NULL)
      printf(" no se puede crear archivo \n \n");
      else{
    printf("archivo abierto\n");
    *conta=fread(datos,sizeof(Datos),max,archivo);
    while(feof(archivo)==0)
      *conta=fread(datos,sizeof(Datos),max,archivo);
    fclose(archivo);
  }
}

void guardar(Datos datos[max],int *conta)
{char N_archi[50];
int cont;
cont=*conta;
   FILE *archivo;
   printf("Proporcione el nombre del archivo\n");
   scanf("%s",N_archi);      
      strcat(N_archi,".dat");
      archivo=fopen(N_archi,"wb");
      if(archivo){
         fwrite(datos,sizeof(Datos),cont,archivo);
         fclose(archivo);
         printf("Archivo guardado\n");}
      else
         printf("Archivo no guardado\n");
}

//Registro de alumno//
void registro(Datos datos[max],int *conta)
{
  int cont=0,i,a=0,res,b=0;
  float prom=0;
 
  do { 
    cont=*conta;
    printf("Registro de un alumno\n");
   printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
   do{
    printf("Ingrese la matricula del alumno\n");
    scanf("%d",&datos[cont].matricula);
    a=0;
   for (i=0;i<cont;i++){
     if((datos.matricula)==(datos[i+1].matricula)){
       a=1;
       printf("La matricula esta repetida\n");}
   }
 }while(a==1);
  printf("Ingrese el apellido paterno del alumno\n");
     scanf("%s",datos[cont].alum.apellidop);
     for(i=0;i<strlen(datos[cont].alum.apellidop);i++)
     datos[cont].alum.apellidop=toupper(datos[cont].alum.apellidop);
     printf("Ingrese el apellido materno del alumno\n");
     scanf("%s",datos[cont].alum.apellidom);
     for(i=0;i<strlen(datos[cont].alum.apellidom);i++)
     datos[cont].alum.apellidom=toupper(datos[cont].alum.apellidom);
     printf("Ingrese el nombre del alumno\n");
     scanf("%s",datos[cont].alum.nombre);
     for(i=0;i<strlen(datos[cont].alum.nombre);i++)
     datos[cont].alum.nombre=toupper(datos[cont].alum.nombre);
     do{
       printf("ingrese la edad de el alumno\n");
       scanf("%d",&datos[cont].edad);
       if(datos[cont].edad<1)
       printf("Error la edad debe ser mayor a 0\n");
     }while(datos[cont].edad<1);
     getchar();
     do{
     printf("ingrese el sexo de el alumno(F/M)\n");
     scanf("%c",&datos[cont].sexo);
     b=0;
      if (datos[cont].sexo!='M' && datos[cont].sexo!='m' && datos[cont].sexo!='F' && datos[cont].sexo!='f'){
      b=1;
       printf("proporcione el sexo correcto\n");
       getchar();}
     datos[cont].sexo=toupper(datos[cont].sexo);
     }while(b==1);
     
     for(i=0;i<3;i++){
     do {
       printf("Ingrese la calificacion del departamental %d\n",i+1);
       scanf("%f",&datos[cont].dep);
       if (datos[cont].dep<0 ||datos[cont].dep>10)
       printf("la calificacion debe estar entre 0 a 10\n");
     } while(datos[cont].dep<0 || datos[cont].dep>10);
           prom=prom+datos[cont].dep;
         }
     datos[cont].prom=prom/3;
     printf("promedio de el alumno es %.2f\n",datos[cont].prom);
    printf("Desea ingresar los datos de otro alumno\n");
     printf("0.-no, 1.- si\n");
     scanf("%d",&res);
      cont++;
     printf(" alumnos registrados %d\n",cont);
     *conta=cont;
     prom=0;
     
 }while(res!=0 && cont<max);
}

//muestra todos los alumnos registrados//
void todos(Datos datos[max],int *conta)   //imprime todos lo alumnos registrados
 { int cont=0,i;
    cont=*conta;
   for(i=0;cont>i;i++)
     printf("N:%d  %d: %s, %s, %s, %d, %c,%.2f\t\n",i+1,datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
    printf("\n");
   }



//lista de aprobados//
void lista_a(Datos datos[max],int *conta)   //imprime todos lo alumnos que tengan promedio mayor a 5
 { int cont=0,i;
    cont=*conta;
   for(i=0;cont>i;i++)
   {if(datos.prom>=6)
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
    printf("\n");
   }
}

//lista de reprobados//
void lista_r(Datos datos[max],int *conta) //imprime todos lo alumnos que tengan promedio menor a 6
{ int i,cont=0;
   cont=*conta;
  for(i=0;i<cont;i++)
  {if(datos.prom<6)
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
   printf("\n");
  }
}

//promedio//
void prom(Datos datos[max],int *conta) //suma el promedio de cada alumno y lo divide entre el total de alumnos registrados
{
  int i,cont=0;
  float prome=0,pro=0;
cont=*conta;
  for(i=0;i<cont;i++)
  prome=datos.prom+prome;
  pro=prome/(cont);
  printf("el promedio general de el grupo es %.2f \t\n\n",pro);
}

void eliminar(Datos datos[max],int *conta)
{
   int i, j, matricu, encontrado,cont=0;
   encontrado = 0;
   cont=*conta;
   printf("\nIngresa matricula: ");
   scanf("%d", &matricu);
   for (i=0; i<cont; i++) {
      if(datos.matricula == matricu) {      //al encontrar la matricula la variable "encontrado" cambia de valor
         encontrado = 1;
         for(j=i; j<cont; j++)
            if (j+1 != cont)
               datos[j].matricula = datos[j+1].matricula;
      }
   }
    if (encontrado==1) {
      cont--;
      *conta=cont;
      printf("\nEl alumno con la matricula %d, fue eliminado del registro.\n",matricu);
   } else
      printf("\nEl alumno con la matricula %d, no fue encontrado en el registro.\n",matricu);

}

//*modulo de busqueda*//
void busqueda(Datos datos[max],int *conta)
{int i,matri=0,res,cont=0,a;
   cont=*conta;
do{
   a=0;
  printf("ingrese la matricula del alumno a buscar\n");   //al encontrar la matricula la variable "a" cambia de valor
  scanf("%d",&matri);
  for(i=0;i<cont;i++)
    if(matri==datos.matricula){
    a=1;
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
 }
 if(a==0){
    printf("la matricula ingresada no es correcta o no existe ese alumno\t\n\n");}
 printf("desea buscar otro alumno\t\n");
  printf("0.- no, 1.- si\n");
  scanf("%d",&res);
}while(res!=0);
}


//consulta informacion de un alumno//
void consulta(Datos datos[max],int *conta)
{
  int x;
  do{
    printf("Usted selecciono consulta de informacion\n");
   printf("1.-Todos los alumnos\n");
    printf("2.-Busqueda de un alumno\n");
    printf("3.-Lista de reprobados\n");
    printf("4.-Lista de aprobados\n");
    printf("5.-Promedio Gral\n");
    printf("6.-Salir al menu principal\n");
    scanf("%d",&x);
    switch (x) {
      case 1:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono mostar todos lo alumnos registrados\n");
      todos(datos,conta);//entra la estructura datos y el contador de alumnos e imprime a todos lo alumnos registrados
      break;
     
      case 2:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono buscar un alumno\n");
      busqueda (datos,conta);//entra la estructura datos y el contador de alumnos y solo imprime los datos de alumno seleccionado
      break;
     
      case 3:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono mostrar todos los alumnos reprobados\n");
      lista_r (datos,conta);//entra la estructura datos y el contador de alumnos e imprime a los alumnos reprobados
      break;

      case 4:
       printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
       printf("Usted selecciono mostrar todos los alumnos aprobados\n");
      lista_a (datos,conta);//entra la estructura datos y el contador de alumnos e imprime a los alumnos aprobados
      break;

      case 5:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("Usted selecciono mostrar el promedio general de los alumnos\n");
      prom (datos,conta);//entra la estructura datos y el contador de alumnos e imprime el promedio general de el gurpo
      break;

      case 6:
      printf("*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*\n");
      printf("selecciono salir al menu anterior\n");
      break;

      default:
      printf("por favor seleccione una opcion valida\n");
    }
  }while(x!=6);
}


 
  void ordena(Datos datos[max],int *conta)//entra la estructura datos y el contador de alumnops y solo imprime lo que se pide
 {
    int i, x,j,cont=0;
    Datos aux;
    cont=*conta;
 do{
    printf("desea ordenar por:\n");
    printf("1.-Promedio\n");
    printf("2.-Edad\n");
    printf("3.-Nombre\n");
    printf("4.-Matricula\n");
    printf("5.-Salir\n");
    scanf("%d",&x);
    switch (x){
      case 1:
      printf("ordenamiento por Promedio\n");
      for(i=0;i<cont;i++){
         j=i;
        while(j>0 && datos[j].prom<datos[j-1].prom){   //se intercambian los elementos
            aux=datos[j];
            datos[j]=datos[j-1];
            datos[j-1]=aux;
            j--;
            }
         }
       
      for(i=0;i<cont;i++)
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
    break;

      case 2:
      printf("Ordenamiento por Edad\n");
      for(i=0;i<cont-1;i++){
      for(j=cont-1;j>i;j--)
         {if(datos[j].edad < datos[j-1].edad){   //se intercambian los elementos
            aux=datos[j];
            datos[j]= datos[j-1];
            datos[j-1]=aux;
            }
      }
    }
    for(i=0;i<cont;i++)
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
    break;

      case 3:
      printf("Ordenamiento por Nombre\n");
      for(i=0;i<cont;i++)//Ciclo q realiza el proceso de ordenamiento
      for(j=cont-1;j>0;j--)
          if(strcmp(datos[j].alum.apellidop,datos[j-1].alum.apellidop)<0)
          {
           aux= datos[j];
          datos[j]=datos[j-1];
           datos[j-1]=aux;

          }
      for(i=0;i<cont;i++)
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);

    break;

    case 4:
    printf("Ordenamiento por Matricula\n");
    for(i=0;i<cont-1;i++){
      for(j=cont-1;j>i;j--)
      { if (datos[j].matricula<datos[j-1].matricula){ //se intercambian los elementos
         aux=datos[j];
         datos[j]=datos[j-1];
         datos[j-1]=aux;
         }
      }
      }
    for(i=0;i<cont;i++)
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
  break;

   case 5:
   printf("selecciono salir al menu anterior\n");
   break;

 default:
      printf("error proporcione una opcion valida\n");
      break;

   }
 }while(x!=5);
}


void modificar(Datos datos[max],int *conta)
{ int op=0;
 do
 {
  printf("MODIFICAR REGISTRO\n");
  printf("************************\n");
  printf("1.Modificar Nombre\n");
  printf("2.Modificar Edad\n");
  printf("3.Modificar Sexo\n");
  printf("4.Modificar Calificaciones\n");
  printf("5.-Salir al menu anterior\n");
  printf("Ingrese opcion\n");
  scanf("%d",& op);
     switch (op)
      {
       case 1:
                 modi_nombre(datos,conta);
                 break;
       case 2:
                 modi_edad(datos,conta);
                 break;
       case 3:
                 modi_sexo(datos,conta);
                 break;
       case 4:
                 modi_cal(datos,conta);
                 break;
               
       case 5:
            printf("selecciono Salir al menu anterior\n");
            break;
      default:
            printf("Proporcione una opcion valida\n");
      }
 }while(op!=5);
}


void modi_nombre(Datos datos[max],int *conta)
{
int matri,res,a,cont,j,i;
 cont=*conta;
   printf("Modificar Edad\n");
   todos(datos,conta);
   do{
   a=0;
  printf("ingrese la matricula del alumno a buscar\n");   //al encontrar la matricula la variable "a" cambia de valor
  scanf("%d",&matri);
  for(j=0;j<cont;j++)
    if(matri==datos[j].matricula){
    a=1;
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos[j].matricula, datos[j].alum.apellidop, datos[j].alum.apellidom, datos[j].alum.nombre,datos[j].edad, datos[j].sexo,  datos[j].prom);
               printf("\n\tIngrese el nombre\n\t");
               printf("Ingrese el apellido paterno del alumno\n");
               scanf("%s",datos[j].alum.apellidop);
               for(i=0;i<strlen(datos[j].alum.apellidop);i++)
               datos[j].alum.apellidop=toupper(datos[j].alum.apellidop);
               printf("Ingrese el apellido materno del alumno\n");
               scanf("%s",datos[j].alum.apellidom);
               for(i=0;i<strlen(datos[j].alum.apellidom);i++)
               datos[j].alum.apellidom=toupper(datos[j].alum.apellidom);
               printf("Ingrese el nombre del alumno\n");
               scanf("%s",datos[j].alum.nombre);
               for(i=0;i<strlen(datos[j].alum.nombre);i++)
               datos[j].alum.nombre=toupper(datos[j].alum.nombre);
               guardar(datos,conta);}
 if(a==0){
    printf("la matricula ingresada no es correcta o no existe ese alumno\t\n\n");}
 printf("desea buscar otro alumno\t\n");
  printf("0.- no, 1.- si\n");
  scanf("%d",&res);
}while(res!=0);                     
}

void modi_edad(Datos datos[max],int *conta)
{
int matri,res,a,cont,i;
cont=*conta;
   printf("Modificar Edad\n");
   todos(datos,conta);
   do{
   a=0;
  printf("ingrese la matricula del alumno a buscar\n");   //al encontrar la matricula la variable "a" cambia de valor
  scanf("%d",&matri);
  for(i=0;i<cont;i++)
    if(matri==datos.matricula){
    a=1;
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
        do{
                  printf("ingrese la edad de el alumno\n");
                  scanf("%d",&datos.edad);
                  if(datos.edad<1)
                  printf("Error la edad debe ser mayor a 0\n");
                }while(datos.edad<1);
                getchar();
                guardar(datos,conta);}
 if(a==0){
    printf("la matricula ingresada no es correcta o no existe ese alumno\t\n\n");}
 printf("desea buscar otro alumno\t\n");
  printf("0.- no, 1.- si\n");
  scanf("%d",&res);
}while(res!=0);                  
}

void modi_cal(Datos datos[max],int *conta)
{
int matri,res,a,j,cont,i;
float prom=0;
 cont=*conta;
   printf("Modificar Calificacion\n");
   todos(datos,conta);
   do{
   a=0;
  printf("ingrese la matricula del alumno a buscar\n");   //al encontrar la matricula la variable "a" cambia de valor
  scanf("%d",&matri);
  for(j=0;j<cont;j++)
    if(matri==datos[j].matricula){
    a=1;
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos[j].matricula, datos[j].alum.apellidop, datos[j].alum.apellidom, datos[j].alum.nombre,datos[j].edad, datos[j].sexo,  datos[j].prom);
        for(i=0;i<3;i++){
     do {
            printf("Ingrese la calificacion del departamental %d\n",i+1);
            scanf("%f",&datos[j].dep);
            if (datos[j].dep<0 ||datos[j].dep>10)
            printf("la calificacion debe estar entre 0 a 10\n");
          } while(datos[j].dep<0 || datos[j].dep>10);
               prom=prom+datos[j].dep;
             }
          datos[j].prom=prom/3;
          printf("promedio de el alumno es %.2f\n",datos[j].prom);
          guardar(datos,conta);
         }
 if(a==0){
    printf("la matricula ingresada no es correcta o no existe ese alumno\t\n\n");}
 printf("desea buscar otro alumno\t\n");
  printf("0.- no, 1.- si\n");
  scanf("%d",&res);
}while(res!=0);                  
}

void modi_sexo(Datos datos[max],int *conta)
{
int matri,res,a,cont,i;
 cont=*conta;
   printf("Modificar Sexo\n");
   todos(datos,conta);
   do{
   a=0;
  printf("ingrese la matricula del alumno a buscar\n");   //al encontrar la matricula la variable "a" cambia de valor
  scanf("%d",&matri);
  for(i=0;i<cont;i++)
    if(matri==datos.matricula){
    a=1;
     printf("%d: %s, %s, %s, %d, %c,%.2f\t\n",datos.matricula, datos.alum.apellidop, datos.alum.apellidom, datos.alum.nombre,datos.edad, datos.sexo,  datos.prom);
     printf("ingrese el sexo de el alumno(F/M)\n");
    scanf("%c",&datos.sexo);
   if (datos.sexo!='M' && datos.sexo!='m' && datos.sexo!='F' && datos.sexo!='f'){
   printf("proporcione el sexo correcto\n");
   getchar();}
   datos.sexo=toupper(datos.sexo);
   guardar(datos,conta);
 }
 if(a==0){
    printf("la matricula ingresada no es correcta o no existe ese alumno\t\n\n");}
 printf("desea buscar otro alumno\t\n");
  printf("0.- no, 1.- si\n");
  scanf("%d",&res);
}while(res!=0);                  
   
}



Título: Re: Ordenamiento de nombres en C#
Publicado por: BardoArmas en 24 Noviembre 2018, 06:29 am
Manda el código para ver cómo estás almacenando los alumnos, para ver si son estructuras, arrays...

De todas formas es simple, comparas un apellido con otro y si uno es menor, ese va primero y si son iguales, comparas el otro.

Listo colo que el código lo único que no me funciona es el ordenamiento por nombre. Solo lo hice por apellido pero no se como anexarle lo demás.


Título: Re: Ordenamiento de nombres en C#
Publicado por: K-YreX en 24 Noviembre 2018, 07:20 am
Aquí te dejo una versión que acabo de hacer simplificada para que veas la parte del ordenamiento. Lo que hay que hacer una vez se tienen los alumnos con sus respectivos nombres y apellidos, se comparan los apellidos del padre y el que sea menor se pone primero; si son iguales, se compara el de la madre y el menor se pone primero; y si son iguales, se comparan los nombres y el primero se pone primero.

Si tienes dudas sobre el valor de retorno de <strcmp> es el siguiente:
< 0 si la primera cadena es menor que la segunda.
> 0 si la primera cadena es mayor que la segunda.
= 0 si las dos cadenas son iguales.

Adapta esto a tu programa. Suerte.

Código
  1. #include <stdio.h>
  2. #include <string.h>
  3.  
  4. #define TAM 20
  5. #define MAX_STUDENTS 3
  6.  
  7. typedef struct{
  8. char name[TAM];
  9. char lastNameFather[TAM];
  10. char lastNameMother[TAM];
  11. } Student;
  12.  
  13. void initializeStudent(Student*, char*, char*, char*);
  14. void showStudent(Student);
  15. void sortStudents(Student*);
  16.  
  17. int main(){
  18. Student st1, st2, st3;
  19.  
  20. initializeStudent(&st1, "aaaa", "baba", "cccd");
  21. initializeStudent(&st2, "aaaa", "abab", "cccc");
  22. initializeStudent(&st3, "aaab", "baba", "cccc");
  23.  
  24. Student students[MAX_STUDENTS] = {st1, st2, st3};
  25.  
  26. puts("Alumnos sin ordenar");
  27. for(size_t i = 0; i < MAX_STUDENTS; i++)
  28. showStudent(students[i]);
  29.  
  30. sortStudents(students);
  31.  
  32. puts("\nAlumnos ordenados");
  33. for(size_t i = 0; i < MAX_STUDENTS; i++)
  34. showStudent(students[i]);
  35. }
  36.  
  37. void initializeStudent(Student *st, char *name, char *lastNameFather, char *lastNameMother){
  38. strncpy(st->name, name, TAM);
  39. strncpy(st->lastNameFather, lastNameFather, TAM);
  40. strncpy(st->lastNameMother, lastNameMother, TAM);
  41. }
  42.  
  43. void showStudent(Student st){
  44. printf("%s\t%s\t%s\n", st.lastNameFather, st.lastNameMother, st.name);
  45. }
  46.  
  47. void sortStudents(Student *students){
  48. Student assistant;
  49. for(size_t i = 0; i < MAX_STUDENTS-1; i++){
  50. if(strcmp(students[i].lastNameFather, students[i+1].lastNameFather) > 0){
  51. assistant = students[i];
  52. students[i] = students[i+1];
  53. students[i+1] = assistant;
  54. }
  55. else if(strcmp(students[i].lastNameFather, students[i+1].lastNameFather) == 0){
  56. if(strcmp(students[i].lastNameMother, students[i+1].lastNameMother) > 0){
  57. assistant = students[i];
  58. students[i] = students[i+1];
  59. students[i+1] = assistant;
  60. }
  61. else if(strcmp(students[i].lastNameMother, students[i+1].lastNameMother) == 0){
  62. if(strcmp(students[i].name, students[i+1].name) > 0){
  63. assistant = students[i];
  64. students[i] = students[i+1];
  65. students[i+1] = assistant;
  66. }
  67. }
  68. }
  69. }
  70. }


Título: Re: Ordenamiento de nombres en C#
Publicado por: CalgaryCorpus en 24 Noviembre 2018, 11:01 am
Qué tal si concatenas los 3 valores y haces solo 1 comparación?


Título: Re: Ordenamiento de nombres en C#
Publicado por: K-YreX en 24 Noviembre 2018, 11:05 am
El problema es que no tienen porqué ser la misma cantidad de caracteres. Entonces no puedes formar una única palabra. No sé si me entiendes.


Título: Re: Ordenamiento de nombres en C#
Publicado por: BardoArmas en 24 Noviembre 2018, 15:07 pm
Muchas gracias iré a probarlo


Título: Re: Ordenamiento de nombres en C#
Publicado por: K-YreX en 24 Noviembre 2018, 16:03 pm
Sí que es cierto que si quieres concatenar todo podrías hacerlo concatenando un espacio entre palabra y palabra para saber donde acaba cada campo pero te metes en muchos líos. La mejor opción creo que sería (como hacemos lo mismo 3 veces cambiando sólo el campo que comparamos) crear una función que reciba dos parámetros y los compare y así podemos llamarla 3 veces usando como parámetros primero el apellido paterno, luego el materno y luego el nombre y así ese trozo de código queda más limpio. Es decir buscar el trozo de código que repetimos y crear una función (principio de una única vez).


Título: Re: Ordenamiento de nombres en C#
Publicado por: CalgaryCorpus en 24 Noviembre 2018, 16:20 pm
Parece mejor hacer una funcion que compare y solo 1 intercambio, algo asi como:

Código
  1. if( mayor( student1, student2 ) ) {
  2.     // intercambiar
  3. }
  4.  


Sugiero corregir la funcion de ordenamiento que al parecer le falta un ciclo al interior del que ya esta, sino no va a ordenar completamente el arreglo.


Título: Re: Ordenamiento de nombres en C#
Publicado por: K-YreX en 24 Noviembre 2018, 16:24 pm
Parece mejor hacer una funcion que compare y solo 1 intercambio, algo asi como:
Código
  1. if( mayor( student1, student2 ) ) {
  2.     // intercambiar
  3. }
Sugiero corregir la funcion de ordenamiento que al parecer le falta un ciclo al interior del que ya esta, sino no va a ordenar completamente el arreglo.

Exacto con una función puedes modularizar el programa para no hacerlo como lo he hecho en el código de ejemplo, claro que yo lo había hecho para dar la idea de como ordenar por eso no he creado una función auxiliar.
Y a qué te refieres con que le falta un ciclo? No lo veo.


Título: Re: Ordenamiento de nombres en C#
Publicado por: CalgaryCorpus en 24 Noviembre 2018, 16:37 pm
Ordenar es un problema clasico. Mira como ordenar un arreglo y veras que se hace con 2 ciclos, no con 1, a menos que me estoy saltando un detalle que no veo.


Título: Re: Ordenamiento de nombres en C#
Publicado por: K-YreX en 24 Noviembre 2018, 16:42 pm
Es cierto, aquí al ser sólo 3 elementos ha dado la casualidad de que por el orden en que han sido introducidos con un ciclo quedan ordenados pero es cierto que faltaría otro ciclo ya que ese solo ordena el elemento <i> con el <i+1> pero no compara el <i+1> con el <i-1> para valores de <i> mayores que 0.
Es decir que tienes razón, faltaría un segundo ciclo para ordenar completamente el array si la situación en que son introducidos los elementos no es favorable, ya que en este caso sí que lo es y por eso no me había dado cuenta.