Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-01-2014, 12:08   #1
Ingen2
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
[JAVA] Metodo ricorsivo boolean aiuto

Ciao a tutti, devo imparare a scrivere metodi ricorsivi che restituiscono valori di tipo boolean.
Ho un problema a scrivere un metodo ricorsivo che riceve in input una stringa (ed altri parametri se servono) e restituisce true se il numero di caratteri minuscoli presenti nella stringa è pari.
Ecco il codice che ho impostato:
(Il primo valore di i che gli viene passato è s.length()-1)

Codice HTML:
private static boolean carattRic(String s, int i){
boolean esito=false;
int tot=0;
int n=s.length();

if(i==0){
if(Character.isLowerCase(s.charAt(0)))
esito=true;
else
esito=false;
 }
else{
for(int p=0; p<=i; p++){
if(Character.isLowerCase(s.charAt(p)))
tot++;}
esito=((tot%2==0)&&carattRic(s,i-1));
 }
return esito;
 }
}
Il problema è che, giustamente, quando un metodo trova un numero dispari di caratteri minuscoli mi da false e quindi ottengo solo false come esito.
Non so come scriverlo...perchè devo legare ogni valore di esito ad un metodo ad un altro metodo ricorsivo e ad una condizione!
Ingen2 è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 12:36   #2
mone.java
Senior Member
 
L'Avatar di mone.java
 
Iscritto dal: May 2008
Città: Seattle (WA)
Messaggi: 306
Per fare un metodo ricorsivo ti conviene procedere cosi:

1) Prima imposti la condizione di uscita, nel tuo caso si tratta di verificare che l'iesimo carattere sia dentro alla stringa

Codice:
if (s.lenght() - 1 == i) {
   retrurn true;
}
poi dopo devi impostare la logica che consiste nel mettere in AND il valore dell'attuale carattere con quello restituito dal resto della stringa...

Codice:
return Character.isLowerCase(s.charAt(0)) && carattRic(s, i++);
il metodo ,o chiamerai cosi:

Codice:
carattRic("Stringa",0);
non ho testato il codice ma la logica comuqnue è questa...

EDIT:
Scusa ho letto adesso meglio e ho visto che si tratta di contare il numero di caratteri pari e restituisce true in caso siano pari (la mia restituisce true nel caso in cui siano tutti lowercase)... In tal caso non devi fare altro che aggiungere un parametro alla funzione che sarebbe il valore di ritorno e fare l check su quello! prova da solo se non riesci fammi sapere!
__________________
"Considerate la vostra semenza fatti non foste a viver come bruti ma per seguir virtute e canoscenza"

Ultima modifica di mone.java : 10-01-2014 alle 12:41.
mone.java è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 12:58   #3
Ingen2
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
Intanto grazie per aver risposto, poi quello che ho in mente è di far invocare questo metodo da un main che gli passa la stringa dopo averla chiesta all'utente, in modo che la stringa in ingresso possa essere qualunque, ad esempio:

Codice HTML:
class Ricorsivo{

public static void main(String args[]){
InputWindow in=new InputWindow();
OutputWindow out=new OutputWindow();
String s=in.readString("Inserisci stringa");
int n=s.length();
out.write("Esito:"+carattRic(s,n-1));
 }

private static boolean carattRic(String s, int i){
boolean esito;
int tot=0;

if(i==0){
esito=false;
 }

else{
for(int p=0; p<=i; p++){
if(Character.isLowerCase(s.charAt(p)))
tot++;}
esito=((tot%2==0)&&carattRic(s,i-1));
 }
return esito;
 }
}
Come hai detto ho fissato la condizione di uscita, l'ho messa per i=0, quindi comincio da s.length()-1 e vado a scendere; poi l'ho corretto e l'ho messo false perchè se il carattere è uno solo per forza è dispari, poi per gli altri ho messo che il valore di ritorno dipenda dai precedenti con:

esito=((tot%2==0)&&carattRic(s,i-1));

il fatto è che (credo perchè il primo mi da false) visto che c'è AND anche tutti gli altri mi danno false.
Solo che ho provato a fargli dare true per i=0 (anche se non dovrebbe quindi), ma non funziona lo stesso, compilare compila ma poi quando esegue se gli do ad esempio:"aaaa" cioè un numero pari di caratteri minuscoli, mi da false comunque. Quindi l'errore deve stare da un'altra parta ma non capisco dov'è!
Ingen2 è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 13:56   #4
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Io mi terrei sul semplice:
Codice:
    public static boolean isEven(String s)
    {
        int l;
        if ((l = s.length()) == 0)  /* Caso base: stringa vuota. In tal caso, e' pari */
            return true;
        if (l == 1)  /* Caso base: stringa di un carattere. In tal caso, se il carattere e' minuscolo e' dispari */
            return !Character.isLowerCase(s.charAt(0));

        /* passo ricorsivo: divido in due la stringa e controllo le singole parti. Se entrambi sono pari o dispari, il risultato e' pari */
        /* Potrei non dividere in due e controllare un carattere ed il rimanente, ma mi piaceva cosi' */
        boolean a = isEven(s.substring(0,l/2));
        boolean b = isEven(s.substring(l/2));
        return (a && b) || (!a && !b);
    }
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 14:02   #5
mone.java
Senior Member
 
L'Avatar di mone.java
 
Iscritto dal: May 2008
Città: Seattle (WA)
Messaggi: 306
Codice:
class Ricorsivo {

    public static void main(String args[]) {
        String s = "pariPARI";
        System.out.println("Esito:" + carattRic(s, s.length() - 1, 0));
        s = "dispariDISPARI";
        System.out.println("Esito:" + carattRic(s, s.length() - 1, 0));
    }

    private static boolean carattRic(String s, int i, int tot) {
        tot += Character.isLowerCase(s.charAt(i)) ? 1 : 0;

        if (i == 0) {
            return (tot % 2 == 0);
        } else {
            return carattRic(s, --i, tot);
        }
    }
}
EDIT:
La soluzione di sottovento è molto interessante dal punto di vista algoritmico!
__________________
"Considerate la vostra semenza fatti non foste a viver come bruti ma per seguir virtute e canoscenza"
mone.java è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 14:23   #6
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da mone.java Guarda i messaggi
EDIT:
La soluzione di sottovento è molto interessante dal punto di vista algoritmico!
Beh dai, non e' niente di che. Non fraintendermi, non sto criticando, ma trovo che doversi trascinare un paio di parametri in piu' renda le cose piu' difficili.
D'altronde il problema non era quello di contare i caratteri minuscoli ma di stabilire se il loro numero era pari o dispari, e questo puo' essere fatto piu' facilmente, no?
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 14:39   #7
mone.java
Senior Member
 
L'Avatar di mone.java
 
Iscritto dal: May 2008
Città: Seattle (WA)
Messaggi: 306
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Beh dai, non e' niente di che. Non fraintendermi, non sto criticando, ma trovo che doversi trascinare un paio di parametri in piu' renda le cose piu' difficili.
D'altronde il problema non era quello di contare i caratteri minuscoli ma di stabilire se il loro numero era pari o dispari, e questo puo' essere fatto piu' facilmente, no?
Dicevo che il tuo è interessante dal punto di vita algoritmico perchè usa divite et impera che comunque è un approccio interessante ai problemi, indipendentemente dal fatto che io preferissi un'altra soluzione. Quando facevo io l'università e ci facevano fare la ricorsione con scheme facevo prima il metodo con gli n parametri e poi l'overload he semplicemente nascondeva i parametri ijn pi... questione di abitudine
__________________
"Considerate la vostra semenza fatti non foste a viver come bruti ma per seguir virtute e canoscenza"
mone.java è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 17:01   #8
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
return (a && b) || (!a && !b);
può essere sintetizzata nell'equivalente:
Codice:
return a == b;
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 17:07   #9
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
può essere sintetizzata nell'equivalente:
Codice:
return a == b;
Sono un pollo. Non per niente volo sottovento

Quindi il metodo diventa:
Codice:
public static boolean isEven(String s){
    int l = s.length();
    return (l == 0) ? true : (l == 1) ?  !Character.isLowerCase(s.charAt(0)) : isEven(s.substring(0,l/2)) == isEven(s.substring(l/2));
}
__________________
In God we trust; all others bring data

Ultima modifica di sottovento : 10-01-2014 alle 17:12.
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 17:47   #10
Ingen2
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
Grazie per le risposte!
Con le stringhe adesso mi più chiaro, ma vorrei chiedervi un'altra cosa se possibile:
Se volessi creare un metodo ricorsivo che restituisce true se la somma degli elementi di un array (ad esempio di interi) è pari, si potrebbe scrivere qualcosa di simile al caso della stringa?

Ho provato a scriverlo ma non mi è venuto niente di meglio:
Codice HTML:
private static boolean ricorsivo(int[] a, int i){
boolean esito;
int n=a.length;
int somma=0;

if(n==0)
esito=true;
else{

if(i==n-1){
for(int j=0; j<=i; j++)
somma+=a[j];
esito=(somma%2==0);}

else
esito=ricorsivo(a,i+1);
  }
return esito;
  }
La ricorsione c'è poco perchè serve solo per arrivare al caso i=n-1 per il quale si fa la somma...vorrei trovare una soluzione "più ricorsiva"...
Ingen2 è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 17:58   #11
mone.java
Senior Member
 
L'Avatar di mone.java
 
Iscritto dal: May 2008
Città: Seattle (WA)
Messaggi: 306
Quote:
Originariamente inviato da Ingen2 Guarda i messaggi
Grazie per le risposte!
Con le stringhe adesso mi più chiaro, ma vorrei chiedervi un'altra cosa se possibile:
Se volessi creare un metodo ricorsivo che restituisce true se la somma degli elementi di un array (ad esempio di interi) è pari, si potrebbe scrivere qualcosa di simile al caso della stringa?

Ho provato a scriverlo ma non mi è venuto niente di meglio:
Codice HTML:
private static boolean ricorsivo(int[] a, int i){
boolean esito;
int n=a.length;
int somma=0;

if(n==0)
esito=true;
else{

if(i==n-1){
for(int j=0; j<=i; j++)
somma+=a[j];
esito=(somma%2==0);}

else
esito=ricorsivo(a,i+1);
  }
return esito;
  }
La ricorsione c'è poco perchè serve solo per arrivare al caso i=n-1 per il quale si fa la somma...vorrei trovare una soluzione "più ricorsiva"...
Stai sbagliando completamente approccio... quel for non deve esistere altrimenti la ricorsività non ha senso. Quello che devi fare (prendi spuno dagli esempi sopra) è valutare ad ogni passo della ricorsione l'n-esimo elemento dell'array (oppure l'n-1 esimo dipende se parti dalla cima o dal fondo). Quindi ogni volta che fai la chiamata ricorsiva devi passare l'input attuale meno l'elemento valutato.. Ovviamente potremmo metterti la soluzione anche di questo esercizio ma non impareresti molto. Intanto parti eliminando il ciclo for, in genere nelle funzioni ricorsive non si dovrebbero vedere cicli for in quanto il ciclo è ottenuto attraverso le chiamate ricorsive!
__________________
"Considerate la vostra semenza fatti non foste a viver come bruti ma per seguir virtute e canoscenza"
mone.java è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 18:47   #12
Ingen2
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
Allora non potendo pensare di dividere l'array(?) ho riscritto così il metodo, che sembra funzionare:

Codice HTML:
private static boolean ricorsivo(int[] a, int i, int numdispari) {

if(a.length==0)
return true;

  if(a[i]%2==0)
  numdispari=numdispari;
  else
  numdispari++;

if (i==0)
return (numdispari%2==0);
else
return ricorsivo(a, i-1, numdispari);

 }
Quindi come avevi fatto per le stringhe...non potendo dichiarare una variabile da far eventualmente incrementare ogni volta che si fa un chiamata ricorsiva, ti porti dietro il suo valore ogni volta che invochi un nuovo metodo e poi il check lo fai alla fine (cioè quando conta) il cui risultato rappresenta anche il caso base; è corretto?
Ingen2 è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2014, 19:22   #13
mone.java
Senior Member
 
L'Avatar di mone.java
 
Iscritto dal: May 2008
Città: Seattle (WA)
Messaggi: 306
NOn ho controllato se la funzione è precisa ma cmq è giusto quello che dici... se poi facendo i test funziona allora è perfetto.. Un alternativa alla soluzione con i parametri è usare una mtodologia come quella esposta da sottovento.. ma secondo me è un po più complicato...
__________________
"Considerate la vostra semenza fatti non foste a viver come bruti ma per seguir virtute e canoscenza"

Ultima modifica di mone.java : 10-01-2014 alle 19:37.
mone.java è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2014, 08:23   #14
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Stavolta il tuo metodo deve avere un paio di parametri in piu': il punto di partenza all'interno dell'array e la lunghezza della porzione dell'array interessato.
Il motivo e' semplice: nell'implementazione fatta con le stringhe, la substring() creava ogni volta una stringa nuova con le dimensioni corrette. Quindi ad ogni ricorsione si creavano delle stringhe nuove. Pero' tutto era fatto dalla substring() quindi era semplice da scrivere (sebbene, ovviamente, sia stato ben poco efficiente).
Puoi usare lo stesso criterio anche in questo caso; tuttavia, non volendo duplicare tutte le volte l'array, potresti scrivere:

Codice:
    public static boolean isEven(int[] vect, int startIndex, int length)
    {
        if (length == 0)
            return true;
        if (length == 1)
            return (vect[startIndex] % 2) == 0;
        return ((vect[startIndex] % 2) == 0) == isEven(vect, startIndex+1, length-1);
    }
Ovviamente in ingresso alla ricorsione gli devi passare 0 come startIndex ed il numero iniziale degli elementi come length; per esempio:

Codice:
    public static void main(String[] args)
    {
        int[][] arrVect = 
        {
            { 1 },
            { 2 },
            { 1, 2},
            { -1, 2, 3},
            { 1, 2, 3, 4, 5, 6, 7}
        };

        for (int[] vect : arrVect)
            System.out.println ("pari = " + isEven(vect, 0, vect.length));
    }
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2014, 21:38   #15
Ingen2
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
Grazie di nuovo a tutti, questi giorni ho provato a scrivere parecchi metodi ricorsivi utilizzando i consigli che mi avete dato, li ho testati e funzionano bene. Tutti metodi abbastanza semplici, però vabè xD Grazie ancora!
Ingen2 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Arianespace potrebbe lanciare il primo r...
Google Pixel 10a disponibile al prezzo m...
Microsoft Copilot nei guai: email riserv...
AOC a 399€ su Amazon: QD-OLED 240 Hz e 0...
La Cina ha recuperato dal mare il primo ...
Boeing CST-100 Starliner: la NASA rende ...
hiop e TaDa uniscono le forze per trasfo...
Thermal Grizzly mostra il Ryzen 7 9850X3...
AMD Ryzen 'Olympic Ridge' Zen 6 per desk...
Donald Trump renderà pubbliche in...
Prezzo mai visto da mesi: ECOVACS DEEBOT...
Non solo S26, Samsung sta per lanciare a...
Windows 11 avrà a breve uno Speed...
Ask Intel: l'assistente IA che ti aiuta ...
Nasce Freedom.gov: il portale USA per ag...
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: 00:40.


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