Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
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


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Toyota usa giochi e premi per spingere i...
HarmonyOS ha raggiunto la soglia di sopr...
Le offerte Amazon più convenienti...
Un gruppo di ladri ha usato Google Maps ...
Apple non si fida di Samsung per la real...
Windows 11: un nuovo driver nativo mette...
Vi hanno regalato buoni Amazon? Intanto ...
Via acari, polvere e sporco da materassi...
Cuffie Beats in super offerta su Amazon,...
Xbox Cloud Gaming arriva su Amazon Fire ...
Un blackout a San Francisco manda in til...
Windows 11 è diventato più...
Apple cambia strategia a causa della cri...
007 First Light: uscita rimandata di due...
Samsung Galaxy A37 e A57: il comparto fo...
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: 20:32.


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