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("\n Seleccione una opcion: "); 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')
}
}
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