alguien que me pueda ayudar con este problema?

Iniciado por alexandrots, 11 Mayo 2013, 20:40 PM

0 Miembros y 1 Visitante están viendo este tema.

alexandrots

Se solicita codificar un programa en lenguaje C que solucione el siguiente problema: Se inicia con un arreglo que contiene las matriculas de los alumnos inscritos en una clase de programacion,esta lista se encuentra ordenada ascendentemente. El programa permite al usuario agregar una nueva matricula o remover una existente conservando el orden del arreglo. Se debera indicar cuando se haya alcanzado el maximo numero de alumnos que se permiten en la materia y el usuario seleccione la opcion de agregar una matricula; tambien cuando la lista este vacia y el usuario desee dar de baja. Utilice el siguiente esqueleto como base.

#include <stdio.h>

#define CUPO_MAX 25

long lista[CUPO_MAX]= {137982, 145783, 156312, 166357,175013};

short alta(long *gpo, int n);

short baja(long *gpo, int n);

int main(void)
{ short num_alumnos=5;
short op;
do{
print("\n1) Desplegar lista de matriculas");
print("\n2) Agregar a lista de matriculas");
print("\n3) Borrar de la lista de matriculas");
print("\n4) Salir");
printf("\n Seleccione una opcion");
scanf("%hd",&op;
switch(op)
{
case 1: despliega(lista, num_alumnos);
break;

case 2: if (alta(lista,num_alumnos) == 1 ) // si todo salio bien incrementa en uno el contador de alumnos
num_alumnos++;
break;

case 3: if (baja(lista, num_alumnos) == 1 ) // si todo salio bien decrementa en uno el contador de alumnos
num_alumnos--;
break;
case 4: printf("\nGracias por usar el programa");
break;

}

}while (op!= SALIR);
}

amchacon

Terminamos antes si nos dices que problemas te da el código.
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar


pacoperico

Para resolver el problema solo tienes que pasar a codigo el texto de tu enunciado.

dato000

Pues no se entiende del todo lo que quieres, pero no se porque pero este problema me recuerda cuando estaba aprendiendo c/c++ y no entendia nada de nada, todos hemos estado en las mismas, así que por eso te ayudare, no es tan dificil, de hecho, realmente de la forma en que esta planteado el enunciado lo vi muy ineficiente y lo retoque un poco.


/* Se solicita codificar un programa en lenguaje C que solucione el siguiente problema:
Se inicia con un arreglo que contiene las matriculas de los alumnos inscritos en una
clase de programacion,esta lista se encuentra ordenada ascendentemente.
El programa permite al usuario agregar una nueva matricula o remover una existente
conservando el orden del arreglo. Se debera indicar cuando se haya alcanzado el maximo
numero de alumnos que se permiten en la materia y el usuario seleccione la opcion de agregar
una matricula;
tambien cuando la lista este vacia y el usuario desee dar de baja.

Utilice el siguiente esqueleto como base.*/

#include <stdio.h>
#include <stdlib.h>

#define CUPO_MAX 25

//como la lista de matriculas es una variable global, no es necesaria indexarla a las funciones
long lista[CUPO_MAX] = {137982, 145783, 156312, 166357, 175013};

void despliega();
short alta(int n);
short baja(int n);
void ordenar();
void corrimiento(int n);

int main(void)
{
    short num_alumnos=5;
    short op;
    do{
        printf("\n1) Desplegar lista de matriculas");
        printf("\n2) Agregar a lista de matriculas");
        printf("\n3) Borrar de la lista de matriculas");
        printf("\n4) Salir");
        printf("\n Seleccione una opcion: ");
        scanf("%hd",&op);
        switch(op)
        {
            //Despliega solo imprime en pantalla el numero de alumnos, lo que son esos codigos, supongo
            //Por lo tanto no necesita pasar datos a la funcion, solo imprimarla en su totalidad
            case 1: despliega();
                    break;

            case 2: if(alta(num_alumnos) == 1); // si todo salio bien incrementa en uno el contador de alumnos
                    num_alumnos++;
                    break;

            case 3: if (baja(num_alumnos) == 1 ) // si todo salio bien decrementa en uno el contador de alumnos
                    num_alumnos--;
                    break;

            case 4: printf("\nGracias por usar el programa");
                    break;

        }

    }while (op != 4);

    return 0;
}

void despliega()
{
    int i;
    printf("matriculas de la lista:\n\n");
    for(i=0; i <  CUPO_MAX ; i++)
    {
        if (lista[i] != '\0')
           printf("%d, ",lista[i]);
    }
    printf("\n\n");
}

void ordenar()
{
    //Ordenando ascendentemente los numeros del arreglo
    int i, j, temp;
    for (i=1; i<CUPO_MAX; i++)
    {
          for (j=0 ; j< CUPO_MAX - 1; j++)
          {
               if (lista[j] > lista[j+1])
               {
                    temp = lista[j];
                    lista[j] = lista[j+1];
                    lista[j+1] = temp;
               }
          }
    }
}

//agregando matriculas
short alta(int num)
{
    long mat_nueva;
    if(num <= 25)
    {
        printf("Digite el numero de matricula para agregar:  ");
        scanf( "%d", &mat_nueva);
        //como el arreglo empieza en la posicion cero, no se necesita adicionar casilla ahi
        //la suma se realiza en el case, para avanzar a la siguiente casilla del arreglo
        lista[num] = mat_nueva;
        printf("matricula agregada\n");
        ordenar();
        return 1;
    }
    else
    {
        printf("Se ha excedido el numero permitido de matriculas por clase.\n\n");
        return 2;
    }
}

short baja(int num)
{
    long mat_retirada;
    printf("Digite el numero de matricula para retirar:  ");
    scanf( "%d", &mat_retirada);
    //printf("%d", mat_retirada);
    //Se realiza una busqueda de la variable y se compara con los valores en las posiciones del arreglo
    int i;
    for(i=0; i<CUPO_MAX; i++)
    {
        if(mat_retirada == lista[i])
        {
            lista[i] == 0;
            corrimiento(i);
            printf("matricula retirada\n");
            ordenar();
            return 1;
        }

    }

    printf("La matricula NO esta en la lista.\n\n");
    return 2;

}

void corrimiento(int n)
{
    //corriendo los numeros de las posiciones descendentemente
    for( ;n <CUPO_MAX; n++)
    {
        lista[n] = lista[n+1];
    }
}




Creo que le faltan unos detalles, esos te los dejo para que los averigues no seas tan flojo, no esperes nada regalado, un poco de ayuda no viene mal, para eso estamos, pero realmente, en estos temas, hay que hacer cada uno su esfuerzo.

Slds ojala te sirva



alexandrots

Gracias de hecho ese es mi caso, estoy cursando la materia y en realidad no entiendo mucho como crear un programa, fue muy útil tu ayuda, muchas gracias.