|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
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;
}
}
Non so come scriverlo...perchè devo legare ogni valore di esito ad un metodo ad un altro metodo ricorsivo e ad una condizione! |
|
|
|
|
|
#2 |
|
Senior Member
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;
}
Codice:
return Character.isLowerCase(s.charAt(0)) && carattRic(s, i++); Codice:
carattRic("Stringa",0);
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. |
|
|
|
|
|
#3 |
|
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;
}
}
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'è! |
|
|
|
|
|
#4 |
|
Senior Member
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 |
|
|
|
|
|
#5 |
|
Senior Member
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);
}
}
}
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" |
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
|
Quote:
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 |
|
|
|
|
|
|
#7 | |
|
Senior Member
Iscritto dal: May 2008
Città: Seattle (WA)
Messaggi: 306
|
Quote:
__________________
"Considerate la vostra semenza fatti non foste a viver come bruti ma per seguir virtute e canoscenza" |
|
|
|
|
|
|
#8 | |
|
Senior Member
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
|
Quote:
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) |
|
|
|
|
|
|
#9 | |
|
Senior Member
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
|
Quote:
![]() 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. |
|
|
|
|
|
|
#10 |
|
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;
}
|
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: May 2008
Città: Seattle (WA)
Messaggi: 306
|
Quote:
__________________
"Considerate la vostra semenza fatti non foste a viver come bruti ma per seguir virtute e canoscenza" |
|
|
|
|
|
|
#12 |
|
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);
}
|
|
|
|
|
|
#13 |
|
Senior Member
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. |
|
|
|
|
|
#14 |
|
Senior Member
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 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);
}
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 |
|
|
|
|
|
#15 |
|
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!
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 20:32.





















