Problema con funcion, Metodo de seleccion

Iniciado por krowa, 23 Octubre 2011, 05:21 AM

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

krowa

Hola me presento en esta comunidad, estoy estudiando c++en mis ratos libres, cuando tengo tiempo, ya que soy estudiante (16 años.) y no me da mucho el tiempo.
Bueno esto no viene al caso :P,  
Estoy haciendo un programa el cual vos le ingresas la cantidad de posiciones que queres que contenga el vector e ingresas los elementos de cada posicion.
El programa lo que hace es ordenarlos por el metodo de seleccion usando una funcion.
Ya tengo claro el metodo de la burbuja, ( ya lo hice).
Y ahora estoy viendo el metodo de seleccion, se como es, pero quiero realizarlo creando una funcion que seleccione el menor numero del vector y retorne la posicion de ese vector en el cual se encuentra el menor numero.
(Recordemos que estoy en el metodo de seleccion)
Para luego ordenarlo, el problema es que NO funciona, a lo ultimo me muestra el vector, pero cualquier cosa me tira.

ACA EL CODIGO :


#include<iostream>
using namespace std;
int Menor(int v[], int nv,int i){
   int r=0;
                              for(;i<nv;i++){
                                      if(v<v[i+1])r=i;
                                      }
                                      return r;
                                      }
int main()
{
   //CARGA DEL VECTOR ---------------------------------------------------------
   int nv;
   cout<<"Introzuca la cantidad de elementos que desea que tenga el vector: ";
   cin>>nv;
   cout<<endl;
   int v[nv];
   v[nv+1]=0;
   for(int i=0;i!=nv;i++){
                         cout<<"Introduzca valor para la posicion Numero "<<i<<": ";
                         cin>>v;
                         cout<<endl;
                         }
   //FIN DE CARGA DEL VECTOR --------------------------------------------------
   //PROCESO DE ORDENAMIENTO CON LLAMADA A FUNCION MENOR--------------------------------------------------
   int temp,caca;
   for(int i=0;i!=nv;i++){
                          caca=Menor(v,nv,i);
                          temp=v;
                          v=v[caca];
                          v[caca]=temp;
                          }
   //FIN PROCESO DE ORDENAMIENTO -----------------------------------------------
   cout<<"Su vector ordenado: ";
   for(int i=1;i!=nv;i++){
                         cout<<v<<",";
                         }
   system("pause");
}

---

Se que estoy haciendo algo recontra mal, pero no encuentro el error, si me pueden ayudar gracias!

rir3760

Ese programa tiene demasiados errores, si no tienes un libro de calidad revisa los temas fijos de este foro. También puedes utilizar el motor de búsqueda.

En C++ el numero de elementos de un array lo debes indicar mediante una constante, no puedes utilizar una variable:
Código (cpp) [Seleccionar]
int v[nv];

Y aun cuando fuera valido los indices del array van desde 0 hasta nv-1, esto no es un indice valido:
Código (cpp) [Seleccionar]
v[nv+1]=0;
Y tampoco tiene caso ya que la siguiente operación es pedir todos los números.

En el primer bucle de la función principal utilizas el nombre del array "v" cuando deberías utilizar "v[ i ]".

En el siguiente bucle tratas de obtener los "nv" números menores cuando solo debes procesar "nv-1" números. Tanto en ese bucle como en el siguiente utilizas "v" cuando debería ser "v[ i ]".

La función que encuentra el valor menor se debe implementar con solo dos parámetros: la dirección base y el numero de elementos. Por ejemplo:
Código (cpp) [Seleccionar]
int fn_menor(int *elem, int num_elem)
{
int rv;

rv = elem[0];
for (int i = 1; i != num_elem; ++i)
if (rv > elem[ i ])
rv = elem[ i ];

return rv;
}


En buen plan: seria mejor que reescribieras desde cero el programa.

Un saludo
C retains the basic philosophy that programmers know what they are doing; it only requires that they state their intentions explicitly.
--
Kernighan & Ritchie, The C programming language

krowa

Gracias por tu ayuda lo pude hacer :D
Citar
En C++ el numero de elementos de un array lo debes indicar mediante una constante, no puedes utilizar una variable:
Código (cpp) [Seleccionar]
int v[nv];
--
Tengo 1 pregunta :D

Puedo declararlo asi?:
Código (cpp) [Seleccionar]
int N[];   o..
Código (cpp) [Seleccionar]
int N[]= ;
porque?.
--

Citar
En buen plan: seria mejor que reescribieras desde cero el programa.

Un saludo
Excelente, asi lo hice y aca pongo el codigo, anduvo de 10, si llega a tener algun error o algo que "hice" que no deberia haber hecho podrias corregirlo?,
Gracias de nuevo!

Código (cpp) [Seleccionar]

#include <iostream>
using namespace std;

int mostrar(int N[]){    for(int i=0;i!=5;i++){
                   cout<<N[i]<<" ";
                   }
              }

int cargar(int N[]){
         for(int i=0;i<5;i++){
                 cout<<"Introduzca valor para el elemento n"<<i+1<<": ";
                 cin>>N[i];
                 }
         }
int pos_men(int V[],int z){
    int men=0,rat=z;
    men=V[z];
    for(int i=(z+1);i<5;i++){
            if(V[i]<V[rat]){
                         rat=i;
                         }
                           }
    return rat;
}

int main(){
    int N[5],temp=0,g=0;
    cargar(N);
    cout<<"El vector desordenado: ";
    mostrar(N);
    for(int i=0;i<5;i++){
            temp=pos_men(N,i);
            g=N[i];
            N[i]=N[temp];
            N[temp]=g;
            }
            cout<<endl<<endl;
cout<<"El vector ordenado: ";
mostrar(N);
system("pause");
}


Riki_89D

Declararlo asin "int N[]" es quivalente a "int *N" por lo que si puedes,inicializa el puntero con NULL :)

krowa

Cita de: Riki_89D en 24 Octubre 2011, 19:02 PM
Declararlo asin "int N[]" es quivalente a "int *N" por lo que si puedes,inicializa el puntero con NULL :)
Pero si lo delcaro asi queda como un vector? o como una variable?
Osea como "N
  • .." o como "N"?
    Gracias por responder :D

krowa

Cita de: krowa en 24 Octubre 2011, 19:05 PM
Pero si lo delcaro asi queda como un vector? o como una variable?
Osea como
Código (cpp) [Seleccionar]
N[x] o como N?
Gracias por responder :D

Riki_89D

Queda como un puntero,no como un vector (array)

krowa