Programación General > C/C++
Rotar un arreglo arriba o abajo y hallar la moda.
Eriol:
Buen día, mi duda es la siguiente, tengo 2 ejercicios con vectores, arrarys o arreglos como mejor los conozcan y funciones en C++, es decir que tengo que hacer funciones para ello:
1. Debía crear un Vector que leyera N números, y en un menú colocar las opciones de rotar arriba o abajo de la siguiente forma:
Si el usuario ingresa un vector de caracteres:
1 2 3 4
Y elige rotar arriba, debo imprimir el vector original y las nuevas posiciones así:
2 3 4 1
Pero el usuario puede seguir eligiendo bien sea arriba o abajo, que si elige abajo en éste momento el vector vuelve a su posición original y eso, pero si elige arriba, debería mostrar:
3 4 1 2
De éste primer ejercicio, luego de tener una idea me perdí completamente y no he sido capaz de plantearlo como código :ayuda:
2. Y por otro lado, tengo que hallar la moda en otro ejercicio estadístico, partiendo de la base de que la moda es el número que más se repite y que es único.
1 4 4 3 //En éste vector se supone que la moda es 4, pues es el único que se repite
1 1 44 // En éste se supone no hay moda pues hay 2 números que se repiten igual número de veces.
En éste si tengo la idea, pero no sé cómo hacer para que mi código vea que cambio si el contador es igual no hay moda. Lo coloco acá:
--- Código: C++ ---float moda (float v[], int t){ int c=1, a=1; float n=0; for (int i=0;i<t;i++) { for (int j=i+1;j<t;j++) { if (v[i]==v[j]) { c++; } else { if (c>a) { n=v[i]; a=c; c=1; } } } } if (a>-1) return n; else return -1;} Si sólo ingreso un número que se repita por decir algo 2 veces, pues normal, el programa me devuelve ese número como moda, el problema está en si ingreso 2 términos que se repitan igual número de veces, ahí me devuelve el primero que se repitió como moda.
De ante mano, agradezco cualquier ayuda y más aún cualquier cosa que me ayude a aclarar las dudas.
david_lomber:
Aqui te dejo las funciones para rotar, n es el tamaño del vector:
void rotarArriba(int n){
int aux = vec[0];
for (int i=1; i<n; i++)
vec[i-1] = vec[i];
vec[n-1] = aux;
}
//---------------------------------------------------------------------------
void rotarAbajo(int n){
int aux = vec[n-1];
for (int i=n-2; i>=0; i--)
vec[i+1] = vec[i];
vec[0] = aux;
}
Para acomodarlo a tu codigo ya te las arreglas tu solo :P y con lo de la moda.
Saludos!!
Eriol:
Hola David, muchas gracias por ayudar; he modificado un poco ambas funciones y me han quedado así:
--- Código: C++ ---void rotarArriba(int v[], int n){ int aux=v[0], i=0; for (int i=1; i<n; i++) { v[i-1]=v[i]; v[n-1]=aux; }}//---------------------------------------------------------------------------void rotarAbajo(int v[], int n){ int aux = v[n-1], i=0; for (int i=n-2; i>=0; i--) { v[i+1] = v[i]; v[0] = aux; }}
Básicamente lo que hice fue agregar un segundo parámetro que sería el vector que va a intercambiar, ahora el problema es que al ser éstas funciones tipo
--- Código: C++ ---void, deben imprimir el resultado dentro de la misma función, la cosa es que no he podido hacer que imprima los valores correctos, no sé bien dónde poner el
--- Código: C++ ---printf
herzdark:
mm, tu codigo es un poco inentendible, yo lo pondría así, con el printf incluido:
--- Código: C++ ---void rotarArriba(int v[], int n){int aux=v[0], i; for (int i=0; i<n-1; i++) {v[i]=v[i+1]; // en la posición i estoy poniendo el valor de la posición siguiente printf ("%d",v[i]; } v[n-1]=aux;}//---------------------------------------------------------------------------void rotarAbajo(int v[], int n){int aux = v[n-1], i; for (int i=n-1; i>0; i--) {v[i] = v[i-1]; // en la posición i estoy poniendo el valor de la posición anterior printf ("%d";v[i]; } v[0] = aux;}
Eriol:
Bueno, Herzdark, tu código funciona, pero no está imprimiendo uno de lo términos :think:
Navegación
[#] Página Siguiente
Ir a la versión completa