Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi
Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi
Con la prima rete 5G Standalone attiva in Italia, WINDTRE compie un passo decisivo verso un modello di connettività intelligente che abilita scenari avanzati per imprese e pubbliche amministrazioni, trasformando la rete da infrastruttura a piattaforma per servizi a valore aggiunto
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh
OPPO Find X9 Pro punta a diventare uno dei riferimenti assoluti nel segmento dei camera phone di fascia alta. Con un teleobiettivo Hasselblad da 200 MP, una batteria al silicio-carbonio da 7500 mAh e un display da 6,78 pollici con cornici ultra ridotte, il nuovo flagship non teme confronti con la concorrenza, e non solo nel comparto fotografico mobile. La dotazione tecnica include il processore MediaTek Dimensity 9500, certificazione IP69 e un sistema di ricarica rapida a 80W
DJI Romo, il robot aspirapolvere tutto trasparente
DJI Romo, il robot aspirapolvere tutto trasparente
Anche DJI entra nel panorama delle aziende che propongono una soluzione per la pulizia di casa, facendo leva sulla propria esperienza legata alla mappatura degli ambienti e all'evitamento di ostacoli maturata nel mondo dei droni. Romo è un robot preciso ed efficace, dal design decisamente originale e unico ma che richiede per questo un costo d'acquisto molto elevato
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-05-2005, 10:49   #1
luxorl
Senior Member
 
L'Avatar di luxorl
 
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
[JAVA] Avete un'idea come risolvere questo problema?

Allora, mi sono trovato davanti una traccia che chiede di implementare un package puzzle, che prende da file un insieme di lettere messe stile matrice:

Esempio:

Codice:
A C P A S
A P O C S
F R E W A
C O P E O
S L I W Q
E poi prende sempre da file un "dizionario", che contiente una lista di parole.

Un metodo risolvi() accetta una parola del dizionario e deve cercarla nella matrice di lettere a partire da tutte le posizione e verso tutte le direzioni (Una sorta del classico giochino da settimana enigmistica) ...questo metodo risolvi() dovrebbe una volta trovata la parola, restituirla unita alle cordinate della lettera di partenza e alla direzione in cui questa parola si estende.

Esempio:

Codice:
A C P A S
A P O C S
F R E W A
C O P E O
S L I W Q

E' presente la parola APE a partire dalla coordinata <0,0> e si estende verso SUD-EST...
In pratica il mio problema è proprio questo maledetto metodo risolvi()!! Come diavolo potrei farlo?

Grazie in anticipo a chiunque vorrà darmi una mano
__________________
luxorl è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2005, 14:13   #2
niko0
Senior Member
 
L'Avatar di niko0
 
Iscritto dal: Feb 2003
Città: Vicenza, la città del Palladio
Messaggi: 10218
quesito molto interessante!

...ci penso e se mi viene qualche idea... mi faccio vivo

come memorizzi la matrice di lettere?
niko0 è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2005, 14:47   #3
fgmac
Member
 
Iscritto dal: Apr 2000
Messaggi: 138
Un'idea potrebbe essere quella di spezzare il problema in due passi.
Nel primo passo identifichi le sole direzioni utili in base alla lunghezza della parola da cercare :
nell'esempio che facevi, per la posizione 0,0 le direzioni utili sono solo tre: sud, sud-est, est

Fatto questo metodo iterativo sulle lettere.

questa e' la prima idea che mi e' venuta in mente.

ciao,
__________________
fgmac
fgmac è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2005, 15:40   #4
end.is.forever
Senior Member
 
Iscritto dal: Jul 2004
Messaggi: 1578
Codice:
public Vector <Parola> risolvi(Matrice <char> matrice)
{
  Vector <Parola> paroleTrovate = new Vector <Parola>();
  for (int r = 0; r < matrice.numeroRighe(); r++)
    for (int c = 0; c < matrice.numeroColonne(); c++)
    {
      if (r < matrice.numeroRighe())
      {
        paroleTrovate.addRange(cercaInDirezione(matrice, r, c, EST));
        if (c < matrice.numeroColonne())
          paroleTrovate.addRange(cercaInDirezione(matrice, r, c, SUD_EST));
        if (c > 0)
          paroleTrovate.addRange(cercaInDirezione(matrice, r, c, NORD_EST));
      }
      ... uguale per le altre direzioni
    }
  return paroleTrovate;
}

private Vector <Parola> cercaInDirezione(int r, int c, Direzione d)
{
  Vector <Parola> paroleProvate = new Vector <Parola>();
  int numLettere;
  switch (d)
  {
    case EST: numMaxLettere = matrice.numeroColonne() - c;break;
    case SUD_EST:
      int maxC = matrice.numeroColonne() - c;
      int maxR = matrice.numeroRighe() - r;
      numMaxLettere = min(maxC, maxR);
      break;
    ..uguale per le altre direzioni
  }
  for (int numLettere = 2; numLettere < numMaxLettere; numLettere++)
  {
    char[] parolaDaProvare = new char[numLettere];
    for (int i = 0, ri = r; ci = c; i < numLettere; i++)
    {
      parolaDaProvare[i] = matrice.get(ri, ci);
      switch (d)
      {
        case EST: ci++;break;
        case SUD_EST: ci++;ri++;break;
        ..uguale per le altre direzioni
      }
    }
    Parola parola = Dizionario.cercaParola(parolaDaProvare);
    if (parola != null)
      paroleTrovate.add(parola);
  }
  return paroleTrovate;
}
Non ho compilato, ma in linea di massima farei così; una prima ottimizzazione potrebbe essere di considerare solo 4 delle 8 direzioni e poi al momento di testare la parola provarla in entrambi i sensi.
end.is.forever è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi Wind Tre 'accende' il 5G Standalone in Italia: s...
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh OPPO Find X9 Pro: il camera phone con teleobiett...
DJI Romo, il robot aspirapolvere tutto trasparente DJI Romo, il robot aspirapolvere tutto trasparen...
DJI Osmo Nano: la piccola fotocamera alla prova sul campo DJI Osmo Nano: la piccola fotocamera alla prova ...
FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
La missione con equipaggio Shenzhou-21 h...
Il Galaxy S26 Edge potrebbe essere ancor...
Google riaccenderà una centrale n...
Crollo per Pornhub nel Regno Unito:-77% ...
La Germania accende il suo cannone laser...
Il meglio di Amazon in 2 minuti: tira ar...
ECOVACS risponde a Eureka e dimezza il p...
Durissimo colpo per Nintendo: l'ufficio ...
Scope elettriche al minimo storico su Am...
Blue Jay e Project Eluna: robotica e AI ...
Scede a 949€ il Samsung Galaxy S25 Ultra...
Blue Yeti Nano in super offerta su Amazo...
Netflix sta preparando un'offerta per Wa...
Prezzo impossibile, è sceso ancor...
Torna il migliore dei mini PC economici:...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 21:42.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v