Portal    Foro    Buscar    FAQ    Registrarse    Conectarse

Reto 3(nuevo Array Sin Elementos Repetidos)

Reto 3(nuevo Array Sin Elementos Repetidos)
Artículo
Responder citando    Descargar mensaje  
Mensaje Reto 3(nuevo Array Sin Elementos Repetidos) 
 
Buenas les traigo un reto fácil, que me dio dolores de cabeza.
es un reto para novatos y gente que se inicia en gambas.

el reto consiste en que tenemos un array de siglas:

Public ColeccionSiglas As String[] = ["FD", "MTM", "MTM", "ASM", "FD", "CTM", "MTM", "CTM", "FD", "CCR"]

como vereis hay siglas repetidas, pues bien de eso se trata el reto crear un nuevo array que no contenga siglas repetidas.

el reto resuelto seria un nuevo array que recorrido con for each nos dejaria la pantalla así:

FD
MTM
ASM
CTM
CCR

MANDAR EL RETO A MI CORREO
PLAZO UNA SEMANA

NO PUBLIQUEN RETOS RESUELTOS, YO LO HARÉ CUANDO TERMINE EL PLAZO.



 
última edición por v3ctor el Martes, 16 Diciembre 2014, 20:02; editado 2 veces 
v3ctor - Ver perfil del usuario Enviar mensaje privado  
v3ctor [ Martes, 16 Diciembre 2014, 19:07 ]
 


Reto 3(nuevo Array Sin Elementos Repetidos)
Comentarios
Responder citando    Descargar mensaje  
Mensaje Re: Reto 3(nuevo Array Sin Elementos Repetidos) 
 
bueno en vista que no hubo propuestas, el reto esta abierto y cualquiera puede publicar soluciones.

a ver quien da la solución mas elegante.



 
v3ctor - Ver perfil del usuario Enviar mensaje privado  
v3ctor [ Martes, 23 Diciembre 2014, 18:26 ]
Responder citando    Descargar mensaje  
Mensaje Re: Reto 3(nuevo Array Sin Elementos Repetidos) 
 
Es interesante para los más novatos que realicen el ejemplo propuesto.

Esta es una posible solución

' gambas module file

Private ColeccionSiglas As String[] = ["FD", "MTM", "MTM", "ASM", "FD", "CTM", "MTM", "CTM", "FD", "CCR"]

Public Sub Main()

  Dim ColeccionSiglasNoRepetidas As String[]

  ColeccionSiglasNoRepetidas = EliminarRepetidos(ColeccionSiglas)
  MostrarSiglas(ColeccionSiglasNoRepetidas)
    
End

Public Function EliminarRepetidos(siglas As String[]) As String[]
  Dim elemento As String
  Dim sinrepes As New String[]
  
  For Each elemento In siglas
    If Not sinrepes.Exist(elemento) Then sinrepes.Add(elemento)  
  Next
  
  sinrepes.Sort()
  
  Return sinrepes
  
End

Public Sub MostrarSiglas(siglas As String[])
  
  Dim elemento As String
  
  For Each elemento In siglas
    Print elemento
  Next
  
End
 


Saludos



 
Shell - Ver perfil del usuario Enviar mensaje privado  
Shell [ Martes, 23 Diciembre 2014, 20:24 ]
Responder citando    Descargar mensaje  
Mensaje Re: Reto 3(nuevo Array Sin Elementos Repetidos) 
 
Otra forma, esta vez usando Continue dentro del bucle:

Private ColeccionSiglas As String[] = ["FD", "MTM", "MTM", "ASM", "FD", "CTM", "MTM", "CTM", "FD", "CCR"]

Public Sub Main()

Dim siglassinrepeticion As New String[]

siglassinrepeticion = Eliminar_Repetidos(ColeccionSiglas)
siglassinrepeticion.Sort()
MostrarSiglas(siglassinrepeticion)

End

Public Sub Eliminar_Repetidos(siglas As String[]) As String[]
  Dim norepetidos As New String[]
  Dim elemento As String
  
  For Each elemento In siglas
    If norepetidos.Find(elemento) <> -1 Then
      Continue
    Else
      norepetidos.Add(elemento)
    Endif
  Next
  
  Return norepetidos
  
End

Public Sub MostrarSiglas(siglas As String[])
  
  Dim elemento As String
  
  For Each elemento In siglas
    Print elemento
  Next
  
End
 


Saludos



 
Shell - Ver perfil del usuario Enviar mensaje privado  
Shell [ Martes, 23 Diciembre 2014, 20:42 ]
Responder citando    Descargar mensaje  
Mensaje Re: Reto 3(nuevo Array Sin Elementos Repetidos) 
 
En este ejemplo, he usado colecciones. No nos interesa los valores, solo sus claves.

' gambas module file

Private ColeccionSiglas As String[] = ["FD", "MTM", "MTM", "ASM", "FD", "CTM", "MTM", "CTM", "FD", "CCR"]

Public Sub Main()
  
  Dim siglassinrepeticion As New Collection
  
  siglassinrepeticion = Eliminar_Repetidos(ColeccionSiglas)  
  MostrarSiglas(siglassinrepeticion)
  
End

'Más bien cuenta las veces que se repite cada sigla
Public Sub Eliminar_Repetidos(siglas As String[]) As Collection
  
  Dim sigla As String
  Dim csiglas As New Collection
  
  For Each sigla In siglas
    If Not csiglas.Exist(sigla) Then
      csiglas[sigla] = 1
    Else
      csiglas[sigla] += 1
    Endif  
  Next
  Return csiglas
  
End

Public Sub MostrarSiglas(siglas As Collection)
  
  Dim elemento As String
  
  For Each elemento In siglas
    Print siglas.Key
  Next
  
End
 


Lastima no tener Sets en gambas. Pero, se pueden imitar.

Saludos



 
última edición por Shell el Martes, 23 Diciembre 2014, 20:58; editado 1 vez 
Shell - Ver perfil del usuario Enviar mensaje privado  
Shell [ Martes, 23 Diciembre 2014, 20:56 ]
Mostrar mensajes anteriores:    
 
Publicar nuevo tema  Responder al tema  Página 1 de 1
 
 

Usuarios navegando en este tema: 0 registrados, 0 ocultos y 1 invitado
Usuarios registrados conectados: Ninguno


 



 

cron