Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 23-04-2004
JDNA JDNA is offline
Miembro
 
Registrado: mar 2004
Posts: 17
Poder: 0
JDNA Va por buen camino
Question Como saber cual es el número mayor de un array

Hola amigos, queria saber si en el delphi hay algún comando para poder saber que número es el mayor de una lista.
Porque lo clásico es comparar números desde el principio de la lista hasta el final, pero a estas alturas creo que ya debe haber algo que sea más óptimo. Otra solución utilizada es utilizar el algotirmo de ordenación QSort, pero, yo no quiero ordenarlo, solo quiero saber cual es el múmero mayor de una lista. Cuando se trabaja con un cantidad pequeña de datos, vale lo clásico, pero cuando se trata de grandes, realmente grandes cantidades de números, yo creo que ya se debe pensar en utilizar algo más óptimo.
Gracias.

Última edición por JDNA fecha: 23-04-2004 a las 17:03:28.
Responder Con Cita
  #2  
Antiguo 23-04-2004
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.932
Poder: 27
delphi.com.ar Va por buen camino
Si los datos no tienen orden vas a tener que consultar uno por uno los valores del array... Si quieres puedes pensar en hacer algo por bloques en multiples hilos de ejecución, etc... pero a la larga tendrás que consultar todos los items.

Saludos!
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #3  
Antiguo 23-04-2004
Avatar de jachguate
jachguate jachguate is offline
Miembro
 
Registrado: may 2003
Ubicación: Guatemala
Posts: 6.254
Poder: 28
jachguate Va por buen camino
Cool

Cita:
Empezado por JDNA
a estas alturas creo que ya debe haber algo que sea más óptimo.
Mas óptimo no significa mágico... y si te encontras una rutina (que las hay) que te determine el número mayor... esta siempre tendrá que recorrer uno a uno los elementos... es que hay otra forma de "adivinarlo"??

Hasta luego.

__________________
Juan Antonio Castillo Hernández (jachguate)
Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate
Responder Con Cita
  #4  
Antiguo 23-04-2004
Avatar de miguel_fr
miguel_fr miguel_fr is offline
Miembro
 
Registrado: mar 2004
Ubicación: Santiago del estero, Capital
Posts: 73
Poder: 21
miguel_fr Va por buen camino
¿Pierdes mucho espacio si utilizas una variable que se vaya actualizando en cada ingreso?, porque sino te podria servir como puntero, para una futura busqueda.
Ojala que te sirva de algo mi comentario
Responder Con Cita
  #5  
Antiguo 23-04-2004
Avatar de kalimero
kalimero kalimero is offline
Miembro
 
Registrado: may 2003
Ubicación: Alicante
Posts: 288
Poder: 22
kalimero Va por buen camino
Hola:
Prueba con la funcion High(nombrearray) que te devuelve la posicion del ultimo elemento de un array.
Responder Con Cita
  #6  
Antiguo 23-04-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por kalimero
Hola:
Prueba con la funcion High(nombrearray) que te devuelve la posicion del ultimo elemento de un array.
Más precisamente, te devuelve el mayor índice en un arreglo pero lo que se pide es el mayor número de entre los elementos del arreglo.

// Saludos
Responder Con Cita
  #7  
Antiguo 23-04-2004
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.932
Poder: 27
delphi.com.ar Va por buen camino
Cita:
Empezado por kalimero
Hola:
Prueba con la funcion High(nombrearray) que te devuelve la posicion del ultimo elemento de un array.
Me parece que no es lo que está preguntando

Saludos!
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #8  
Antiguo 23-04-2004
Avatar de kalimero
kalimero kalimero is offline
Miembro
 
Registrado: may 2003
Ubicación: Alicante
Posts: 288
Poder: 22
kalimero Va por buen camino
Hola , Disculpas pero lo leí mal. Se pregunta por quien tiene el valor mas alto de los elementos que forman un array y no por el indice mayor.
No conozco nada que lo haga. Si alguna vez me ha hecho falta algo parecido he tenido que inventarme el algoritmo o utilizar alguno de los clasicos que circulan por la red.
Saludos.
Responder Con Cita
  #9  
Antiguo 24-04-2004
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 30
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Smile

¡Hola a todos!


Respondo a la pregunta:
Cita:
Empezado por JDNA
...saber si en el delphi hay algún comando para poder saber que número es el mayor de una lista...
Entendiendo que dicha lista es un arreglo (por lo que dice el título del tema), si dicho arreglo es de enteros (Integer), se puede utilizar la función MaxIntValue; si es de flotantes de precisión doble (Double), se puede utilizar la función MaxValue; las dos funciones pertenecen a la unidad Math de Delphi.


Adicionalmente, buscando la palabra "Mayor" en la biblioteca Delphi Interfaz GH, encuentro algunas funciones de la unidad GHMatem.pas:
Código:
  { Entero Absoluto Mayor }
  Function EnterAbsoMayo (Const Enteros :Array Of Integer) :Integer;

  { Entero de Longitud Mayor }
  Function EnterLongMayo (Const Enteros :Array Of Integer) :Integer;

  { Entero Mayor }
  Function EnterMayo (Const Enteros :Array Of Integer) :Integer;

  { Número de Longitud Mayor }
  Function NumerLongMayo (Const Numeros :Array Of Extended) :Extended;

  { Número Mayor }
  Function NumerMayo (Const Numeros :Array Of Extended) :Extended;
EnterMayo es como MaxIntValue, pero con la ventaja de que puede recibir un arreglo vacío, en cuyo caso devuelve 0 (MaxIntValue asume que el arreglo tiene por lo menos un elemento).

NumerMayo es como MaxValue, pero en lugar de recibir un arreglo de valores Double recibe un arreglo de valores Extended (el tipo estándar de las constantes de punto flotante en Delphi), además de que dicho arreglo puede estar vacío, en cuyo caso devuelve 0 (MaxValue asume que el arreglo tiene por lo menos un elemento).

Les invito a que conozcan esta biblioteca de funciones. En ella encontrarán muchas funciones con las cuales solucionar facilmente cientos de problemas comunes relacionados con números, arreglos, cadenas de caracteres, punteros, memoria, objetos, gramática, etc.

Espero esto sea de utilidad. Seguimos en contacto.

Al González .
Responder Con Cita
  #10  
Antiguo 24-04-2004
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Hola.

Sin ninguna duda está función recorre toda la matriz, que es lo que se quería evitar.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #11  
Antiguo 25-04-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por guillotmarc
que es lo que se quería evitar.
y que no se puede evitar. A menos claro que la lista se mantenga ordenada como indicaste anteriormente con, por ejemplo, un árbol binario; aunque esto solo vale dependiendo de como se obtengan los números, porque si llegan de un solo golpe será más eficiente el recorrido secuencial que el previo ordenamiento.

// Saludos
Responder Con Cita
  #12  
Antiguo 25-04-2004
Julià T. Julià T. is offline
Miembro
 
Registrado: may 2003
Ubicación: en el teclado
Posts: 314
Poder: 22
Julià T. Va por buen camino
también se puede descartar la opción de controlar el máximo con una variable del mismo tipo que el del array cada vez que se entre un nuevo valor al array, ya que funcionaría bién hasta que se elimine el máximo del array con lo que se tendría que "recorrer" el array para buscar el máximo de nuevo.
Responder Con Cita
  #13  
Antiguo 25-04-2004
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por Julià T.
funcionaría bién hasta que se elimine el máximo del array con lo que se tendría que "recorrer" el array para buscar el máximo de nuevo.
Sí, tienes razón. No había pensado en la posibilidad de que se quiten elementos del arreglo. Claro que en realidad poco sabemos de la forma en que lleguen (o se vayan) los números pues no lo aclaró quien originalmente hizo la pregunta.

// Saludos
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 12:20:47.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi