Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media
Nel Formula 1 Technology and Media Centre di Biggin Hill, la velocità delle monoposto si trasforma in dati, immagini e decisioni in tempo reale grazie all’infrastruttura Lenovo che gestisce centinaia di terabyte ogni weekend di gara e collega 820 milioni di spettatori nel mondo
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica
Il nuovo gimbal mobile DJI evolve il concetto di tracciamento automatico con tre modalità diverse, un modulo multifunzionale con illuminazione integrata e controlli gestuali avanzati. Nel gimbal è anche presente un'asta telescopica da 215 mm con treppiede integrato, per un prodotto completo per content creator di ogni livello
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce
Abbiamo provato il nuovo HUAWEI Pura 80 Pro. Parliamo di uno smartphone che è un vero capolavoro di fotografia mobile, grazie ad un comparto completo in tutto e per tutto, In questa colorazione ci è piaciuto molto, ma i limiti hardware e software, seppur in netto miglioramento, ci sono ancora. Ma HUAWEI ha fatto davvero passi da gigante per questa nuova serie Pura 80. Buona anche l'autonomia e soprattutto la ricarica rapida sia cablata che wireless, velocissima.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-11-2007, 12:51   #1
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
[JAVA] Non mi funziona questo algoritmo che calcola le permutazioni di una parola...

Ciao a tutti,
chi mi dice perchè il programma restituisce come permutazioni "null" seguito dalla prima lettera della parola immessa dall'utente?

Codice:
import java.io.*;
import java.math.*;
public class permutazioni {

    public static void main(String[] args) throws IOException {
        // Costruisce l'oggetto di accesso alla tastiera
        BufferedReader input=new BufferedReader(
        new InputStreamReader(System.in)
        );        
        // TODO code application logic here
        String parola="";
        double x;
        int p;
        int I=0;
        int Y=0;
        int flag=0;
        int riempimento=0;
        int K=0;
        
        System.out.println("Inserire la parola di cui eseguire le permutazioni: ");
        parola=input.readLine();
        int lungh=parola.length();  //lunghezza parola di cui calcolarne il fattoriale
        System.out.println(lungh);
        
        int dim=1;
        do{        
            dim=dim*lungh;
            lungh--;
        } while ((lungh-1)>0);
        
        String vet[] = new String [dim];    //crea il vettore di permutazioni [l'indice andrà da 0 a (dim-1)  ]
        vet[0]=parola;
                
        
        for(I=1; I<dim; I++) {
        
        do {            
          flag=0;
            for(Y=0; Y<lungh; Y++){
                x=Math.random();
                p=(int)(x*lungh);
               vet[i]=vet[i]+parola.charAt(p);
            }
        
            for (K=0; K<riempimento; K++) {
               if(vet[i]==vet[K]){
                    flag=1;
                }
            }       
        } while (flag==1);
        riempimento++;
        
        }
        
        System.out.println("Le permutazioni della parola inserita sono:");
        for(I=0; I<dim; I++){
           System.out.println(vet[i]); 
        }        
       
        
    }
    
}
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2007, 14:01   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2780
Codice:
for(I=1; I<dim; I++) {
        
        do {            
          flag=0;
            for(Y=0; Y<lungh; Y++){
                x=Math.random();
                p=(int)(x*lungh);
               vet[i]=vet[i]+parola.charAt(p);
            }
        
            for (K=0; K<riempimento; K++) {
               if(vet[i]==vet[K]){
                    flag=1;
                }
            }       
        } while (flag==1);
        riempimento++;
        
        }
Se l'hai scritto tu mi spieghi cosa stessi tentando di fare? ^^
No comunque seriamente, in questo tipo di problemi non si usano mai funzioni random...
wingman87 è online   Rispondi citando il messaggio o parte di esso
Old 03-11-2007, 14:04   #3
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Codice:
for(I=1; I<dim; I++) {
        
        do {            
          flag=0;
            for(Y=0; Y<lungh; Y++){
                x=Math.random();
                p=(int)(x*lungh);
               vet[i]=vet[i]+parola.charAt(p);
            }
        
            for (K=0; K<riempimento; K++) {
               if(vet[i]==vet[K]){
                    flag=1;
                }
            }       
        } while (flag==1);
        riempimento++;
        
        }
Se l'hai scritto tu mi spieghi cosa stessi tentando di fare? ^^
No comunque seriamente, in questo tipo di problemi non si usano mai funzioni random...
Il ciclo esterno for si preoccupa di scorrere il vettore riempendolo di permutazioni e, per fare ciò, innanzitutto il do while controlla che la permutazione generata non sia uguale ad una già precedentemente generata e memorizzata nel vettore di permutazioni vett.
Il primo for genera la permutazione, invertendo in maniera random la posizione delle lettere, mentre il secondo si preoccupa di stabilire se flag=1 (cioè se la permutazione è già presente nel vettore di permutazioni).
Non so se mi sono spiegato bene...

Comunque, perchè non si usa il random in questo caso? Sclera con le stringhe?
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2007, 20:00   #4
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
Preciso che il programma, così com'è, non calcola le permutazioni bensì le disposizioni con ripetizione, dato che non è stato fatto il controllo ad ogni generazione random dell'indice; se viene generato, su quattro volte, più di una volta lo stesso valore, la nuova stringa conterrà due lettere uguali...
Magari ponendo i numeri prima in un vettore e poi controllando con un flag che nessun numero sia uguale all'altro il problema si risolve.
Tuttavia resta quello del "null" in output seguito dalla prima lettera della parola immessa dall'utente di cui eseguire le permutazioni...
Avete qualche idea per risolvere il problema???
Grazie
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 04-11-2007, 12:13   #5
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
up
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 04-11-2007, 19:40   #6
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2780
Quote:
Originariamente inviato da PaVi90 Guarda i messaggi
Comunque, perchè non si usa il random in questo caso? Sclera con le stringhe?
No, perchè in questo modo in via del tutto teorica l'esecuzione dell'algoritmo potrebbe andare avanti all'infinito, bisogna invece usare un procedimento che passo passo in modo ordinato trova tutte le permutazioni. Con un procedimento del genere puoi anche dire a priori, data la lunghezza della parola quanti cicli impiegherà il programma x generare il risultato.
wingman87 è online   Rispondi citando il messaggio o parte di esso
Old 04-11-2007, 19:45   #7
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
No, perchè in questo modo in via del tutto teorica l'esecuzione dell'algoritmo potrebbe andare avanti all'infinito, bisogna invece usare un procedimento che passo passo in modo ordinato trova tutte le permutazioni. Con un procedimento del genere puoi anche dire a priori, data la lunghezza della parola quanti cicli impiegherà il programma x generare il risultato.
Ok grazie!
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 04-11-2007, 20:01   #8
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2780
Prego, comunque ho trovato gli errori x cui ti scrive sempre null + la prima lettera, te li ho segnati in rosso:
Codice:
import java.io.*;
import java.math.*;
public class permutazioni {

    public static void main(String[] args) throws IOException {
        // Costruisce l'oggetto di accesso alla tastiera
        BufferedReader input=new BufferedReader(
        new InputStreamReader(System.in)
        );
        // TODO code application logic here
        String parola="";
        double x;
        int p;
        int i=0;
        int y=0;
        int flag=0;
        int riempimento=0;
        int k=0;

        System.out.println("Inserire la parola di cui eseguire le permutazioni: ");
        parola=input.readLine();
        int lungh=parola.length();  //lunghezza parola di cui calcolarne il fattoriale
        System.out.println(lungh);

        int dim=1;
        do{
            dim=dim*lungh;
            lungh--;
        } while ((lungh-1)>0);
        lungh=parola.length(); //Nel ciclo precedente avevi modificato il valore di lungh, quindi il random veniva sempre 0

        String vet[] = new String [dim];    //crea il vettore di permutazioni [l'indice andrà da 0 a (dim-1)  ]
        vet[0]=parola;
		

        for(i=1; i<dim; i++) {

			do{
				flag=0;
				vet[i]=""; //Non avevi inizializzato vet[i] che inizialmente vale proprio "null"
				for(y=0; y<lungh; y++){
					x=Math.random();
					p=(int)(x*lungh);
				    vet[i]=vet[i]+parola.charAt(p);
				}
				for (k=0; k<riempimento; k++) {
				    if(vet[i]==vet[k]){
						flag=1;
					}
				}
			} while (flag==1);
			riempimento++;

        }

        System.out.println("Le permutazioni della parola inserita sono:");
        for(i=0; i<dim; i++){
           System.out.println(vet[i]);
        }


    }

}
wingman87 è online   Rispondi citando il messaggio o parte di esso
Old 04-11-2007, 20:04   #9
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
Grazie mille!!!!
Solo ora, grazie a te, mi sono accorto di quegli stupidi errori.
Grazie!!!
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 04-11-2007, 20:05   #10
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
Ora funziona!!!!!!!!!!!!!!!!!!
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media Il cuore digitale di F1 a Biggin Hill: l'infrast...
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica DJI Osmo Mobile 8: lo stabilizzatore per smartph...
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce Recensione Pura 80 Pro: HUAWEI torna a stupire c...
Opera Neon: il browser AI agentico di nuova generazione Opera Neon: il browser AI agentico di nuova gene...
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...
Oltre 55.000 dollari solo per il raffred...
Microsoft e tecnologia immorale: i dipen...
Come stanno andando Fastweb e Vodafone d...
Huawei presenta i nuovi eKit: soluzioni ...
Rockstar spiega i licenziamenti degli sv...
Il "concert phone" definitivo ...
Nintendo punta sul cinema: dopo Mario, a...
Insta360 X4 Air in prova: registra a 360...
PlayStation Portal: arriva lo Streaming ...
iPad Air 13'' (M2) in offerta: sconto di...
Schiaffo al copyright: utilizzare materi...
realme GT 8 Pro porta le fotocamere inte...
JBL Clip 5 a soli 39€ su Amazon: lo spea...
Apple pronta a pagare 1 miliardo l'anno ...
Apple non dimentica gli iPhone più...
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: 13:59.


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