Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16-ak0001nl combina RTX 5080 Laptop e Ryzen AI 9 HX 375 in un desktop replacement potente e ben raffreddato, con display 240 Hz e dotazione completa. Autonomia limitata e calibrazione non perfetta frenano l'entusiasmo, ma a 2.609 euro è tra le proposte più interessanti della categoria.
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-07-2012, 16:42   #1
diegoves
Junior Member
 
Iscritto dal: Oct 2009
Messaggi: 18
Ricorsione in java

Personalmente mi vergogno a scrivere qua per un problema tipo questo, ma è da tempo che non prendo in mano java, e non riesco neanche più a risolvere un problemino simile: dato un numero r contare quante volte si presenta nel numero num tramite ricorsione.
la funzione ricorsiva che ho fatto è:

static int conteggio (int r, int num)
{
if (num%10 == r && num > 0) return 1 + conteggio (r, num/10);
else return conteggio (r, num/10);
}

che ovviamente va in stackoverflow, sapete darmi una mano?? thanks!!
diegoves è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2012, 17:04   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2788
Domanda-Soluzione: Quando termina la ricorsione?
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2012, 18:11   #3
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Domanda-Soluzione: Quando termina la ricorsione?
detto in termini spiccioli, manca la condizione di uscita
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2012, 21:45   #4
diegoves
Junior Member
 
Iscritto dal: Oct 2009
Messaggi: 18
Immaginavo, ma non basta la condizione nel num>0 dato che comunque viene decrementato costantemente fino a 0? (ovvio che non basta, altrimenti nn andrebbe in overflow, però non capisco perché non sia sufficiente come condizione!!)
diegoves è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2012, 21:51   #5
wizard1993
Senior Member
 
L'Avatar di wizard1993
 
Iscritto dal: Apr 2006
Messaggi: 22462
Quote:
Originariamente inviato da diegoves Guarda i messaggi
Immaginavo, ma non basta la condizione nel num>0 dato che comunque viene decrementato costantemente fino a 0? (ovvio che non basta, altrimenti nn andrebbe in overflow, però non capisco perché non sia sufficiente come condizione!!)
perchè in tal caso esegue il secondo ramo dell'if
__________________
amd a64x2 4400+ sk939;asus a8n-sli; 2x1gb ddr400; x850 crossfire; 2 x western digital abys 320gb|| asus g1
Se striscia fulmina, se svolazza l'ammazza
wizard1993 è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2012, 08:07   #6
diegoves
Junior Member
 
Iscritto dal: Oct 2009
Messaggi: 18
Ok, in versione molto scolastica risulta:
public static int conteggio (int r, int num)
* * * * * * * * * * * * {
* * * * * * * * * * * * * * * * if (num>0)
* * * * * * * * * * * * * * * * * * * * {*
* * * * * * * * * * * * * * * * * * * * * * * * if (num%10 == r) return 1 + conteggio (r, num/10);
* * * * * * * * * * * * * * * * * * * * * * * * else return conteggio (r, num/10);
* * * * * * * * * * * * * * * * * * * * }
* * * * * * * * * * * * * * * * else return 0;
* * * * * * * * * * * * }

In versione un po' ridotta?
diegoves è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2012, 09:45   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Puoi verificare subito la condizione di uscita, ad esempio:
Codice:
public static int conteggio(int r, int num) {
    if (num == 0) return 0;
    else if (num%10 == r) return 1 + conteggio(r, num/10);
    else return conteggio (r, num/10);
}
Un'altra soluzione che mi viene in mente è questa (ma in Java la tail recursion non porta alcun vantaggio):
Codice:
public static int conteggio(int r, int num) {
    return conteggio_2(r, num, 0);
}

private static int conteggio_2(int r, int num, int acc) {
    if (num == 0) return acc;
    else return conteggio_2(r, num/10, (num%10 == r) ? acc+1 : acc);
}
__________________

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)

Ultima modifica di banryu79 : 05-07-2012 alle 09:51.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Crollo del mercato PC nel 2026: secondo ...
Come dimostrare che gli agenti di IA fan...
Galaxy AI potrebbe creare app funzionant...
Luce solare anche di notte con i satelli...
The Witcher 4 con ambientazioni da urlo ...
007 First Light e Control Resonant avran...
DLSS 4.5 con Dynamic Multi Frame Generat...
Meta acquisisce Moltbook, il social netw...
Red Hat al MWC 2026: attenzione all'IA n...
Amazon espande 'Paga in Contanti': ora d...
Samsung Galaxy S26 Ultra, promosso ma se...
Gemini sempre più integrato in Go...
NVIDIA investe in Thinking Machines Lab:...
NVIDIA prepara NemoClaw, piattaforma ope...
Samsung testa una batteria da 20.000 mAh...
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: 07:04.


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