border

Miembros:
Mensajes:
Temas:
Online:

Ultimo Miembro:

 
 

Cuenta Bancaria en EEUU

Retroceder   VB-MUNDO - Programacion Visual > Programacion - Lenguajes > Visual Basic 6.00
Registrarse FAQ Miembros Calendario Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
LinkBack Herramientas Desplegado
  #1 (permalink)  
Antiguo 15-11-2008, 16:52:35
Un Nuevo Amigo
 
Registrado: may 2006
Posts: 15
LeandroA Valoración +2
Predeterminado Orderar Matriz utilizando CopyMemory en un solo bucle?

Buenas intento ordenar una matriz alfabeticamente a medida se se van agregando datos a esta, pero no me esta resultando, la idea seria....
(por ejemplo) si el dato ingresado es menor al tercer elemento
copie desde el tercer al final en la posicion 4 de la matriz y en la posicion numero 3 ponga los nuevos datos. pero sin tener que recorrer un bucle, sino mas bien utilzando CopyMemory para hacelerar la funcion.

se que podria poner dos bucles y ordenarlo de la forma tradicional pero esto se haria muy lento si ablamos de 10000 elementos

pongo un ejemplo de lo que intento hacer, pero bien no estoy haciendo buen uso de CopyMemory

Código:
Option Explicit
Private Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlMoveMemory" (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long)

Private Type Datos
    Nombre As String
    Apellido As String
End Type

Dim dPersona() As Datos
Dim lCount As Long

Private Sub Command1_Click()
    AddList "bbb", "bbb"
    ImprimirListado
End Sub

Private Sub Form_Load()
    Me.Show
    ReDim dPersona(0)
    
    AddList "aaa", "aaa"
    AddList "bbb", "bbb"
    AddList "ccc", "ccc"
    AddList "ddd", "ddd"
    AddList "fff", "fff"
    
    ImprimirListado
End Sub

Private Sub ImprimirListado()
    Dim i As Long
    Cls
    For i = 0 To lCount
        Print dPersona(i).Nombre, dPersona(i).Apellido
    Next
End Sub

Private Sub AddList(Nombre As String, Apellido As String)
Dim i As Integer
Dim Ubicado As Boolean

lCount = UBound(dPersona)

If lCount = 0 Then
    dPersona(lCount).Nombre = Nombre
    dPersona(lCount).Apellido = Apellido
Else
    For i = 0 To lCount
        If Nombre < dPersona(i).Nombre Then
            'deberia copiar toda la matriz desde dPersona(i) a al siguiente dPersona(i + 1) todo el resto
            'de la extructura, pero no funciona :(
            CopyMemory ByVal dPersona(i + 1), ByVal dPersona(i), 8 * (lCount - i)
            'luego depositaria los nuevos datos en dPersona(i)
            dPersona(i).Nombre = Nombre
            dPersona(i).Apellido = Apellido
            
            Ubicado = True
            Exit For
        End If
    Next
    
    If Ubicado = False Then
        dPersona(lCount).Nombre = Nombre
        dPersona(lCount).Apellido = Apellido
    End If
End If

ReDim Preserve dPersona(lCount + 1)
End Sub

si alguien sabe como solucionar esto o conose alguna otra forma se los agradezco
Saludos

Última edición por LeandroA fecha: 15-11-2008 a las 17:00:04.
Responder Con Cita
  #2 (permalink)  
Antiguo 16-11-2008, 16:19:24
Avatar de acalanto
Moderador
 
Registrado: dic 2002
Ubicación: Madrid
Posts: 4.307
acalanto ha deshabilitado la reputación
Predeterminado Re: Orderar Matriz utilizando CopyMemory en un solo bucle?

Hace unos dos días que estoy dando vueltas para crear un algorítmo de aceleración de orden, algo parecido a los pares hashing de clave-valor.

Cierto es que con copymemory se puede crear un tratamiento muy rápido de trasponer bloques de memoria, sistema que funciona muy requetebien siempre que se trabaje con arrays de una única dimensión y de longitud conocida (Integer, Long...etcétera).

Lo que de ninguna forma puedes pretender que funcione es tratar de 'trasladar' en memoria un tipo de usuario cuyas cadenas (Strings) son de longitud variable..

CopyMemory copia un NUMERO DE BYTES EXACTO de una posición a otra diferente, pero esta variable debemos indicársela, de lo contrario no te copiará correctamente o incluso puede 'pisar' zonas de memoria ocupadas por otros datos, incluso de otras aplicaciones.

Mucho me temo que como pretendes no es posible hacerlo.

Prueba a crear un array Nombre y otro Apellidos pero de longitud fija, es decir, defínelos como tipo STRING * n y STRING * m respectivamente, donde n y m son las longitudes máximas previstas para cada tipo de dato.


Espero que te resulte útil, y si descubro la forma canónica de ejecutar te la comento.
__________________
Un cordial saludo
-Acalanto-

Madrid - España

Visual Basic
Videos Programacion
Foro Programacion
Tutoriales Programacion

Última edición por acalanto fecha: 16-11-2008 a las 18:35:53.
Responder Con Cita
Respuesta


Herramientas
Desplegado

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
Trackbacks are habilitado
Pingbacks are habilitado
Refbacks are habilitado



La franja horaria es GMT. Ahora son las 01:08:55.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2009, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO 3.1.0
A vBSkinworks Design

Alojado en el servicio Premium de Masquewebs | Diseño mejorado por MasqueWebs

right