Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-01-2011, 16:58   #1
MaxDembo81
Member
 
Iscritto dal: May 2010
Messaggi: 161
Algoritmo da ricorsivo a iterativo

Salve a tutti,
non ricordo/non riesco a trasformare un semplicissimo algoritmo da ricorsivo a iterativo.
L'algoritmo è il seguente

Codice:
 double s(int i, int N, int A{
if (i == 0 ) return 0;
if (i == 1 ) return 1;
else return 2*N*s(i-1,N,A) + (A-N*N)*s(i-2,N,A);}
Com'era la regola generale?
E come lo si traduce questo?

Grazie e scusate la nabbanza
MaxDembo81 è offline   Rispondi citando il messaggio o parte di esso
Old 11-01-2011, 17:56   #2
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Di solito con la risorsione in coda è una stupidaggine tradurlo in iterativo! Ma per quanto riguarda il tuo algoritmo hai a che fare con due chiamate ricorsive quindi non è proprio banale la cosa!
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 11-01-2011, 20:05   #3
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Nel caso pero' si puo' semplificare il tutto mantenendo traccia di quanto valeva la funzione nei passi necessari precedenti.
Ovvero, durante la conta da 1 a i basta memorizzare il valore che la funzione aveva al passo precedente, e quello che aveva al passo precedente ancora.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 11-01-2011, 20:22   #4
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Codice:
double s(int i, int N, int A)
{

  // Il vettore S conterrà i valori del numero che vuoi calcolare
  // inizialmente S[0] = 0 e S[1] = 1.
  // Dopo di che usi gli ultimi due valori per calcolare il prossimo
  // in maniera iterativa, sovrascrivendo di volta in volta il più
  // vecchio, così da mantenere a ogni iterazione gli ultimi 2 valori
  // che ti serviranno a calcolare il prossimo numero

  double S[2] = { 0.0f, 1.0f }; // s(0, N, A) = 0, s(1, N, A) = 1

  int j; // j è il prossimo numero che devi calcolare
  for (j = 2; j <= i; j++)
  {
    // k è l'indice in cui si trova il valore s(j-2, N, A), quindi il più
    // vecchio cioè quello che sostituirai. Ovviamente l'altro valore
    // che ti serve si trova in S[1 - k]
    int k = j % 2;
    S[k] = 2*N*S[1 - k] + (A - N*N)*S[k];
  }

  // Uscito dal ciclo, il valore che cerchi è in 0 se i è pari, in 1 altrimenti
  return S[i % 2];

}
Ma perché double? non può venire un numero con la virgola :E

ps: DOVREBBE funzionare
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2011, 11:42   #5
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
A me la complicazione dell'array con 2 elementi soli e del riferimento se il ciclo e' pari o dispari pare un eccesso poco leggibile.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2011, 19:12   #6
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
per quello c'è più commento che codice
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2011, 14:21   #7
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
per quello c'è più commento che codice


Propongo una cosa simile
(ne' compilato ne' tantomeno testato)

Codice:
double s(int i, int N, int A)
{
  if (i == 0 ) return 0;
  if (i == 1 ) return 1;
  int TM2 = 0;
  int TM1 = 1;
  int TM0;
  for (int q=2; q<=i; q++)
  {
     TM0 = 2*N*TM1 + (A - N*N)*TM2;
     TM2 = TM1;
     TM1 = TM0;
  }
  return TM0;
}
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2011, 15:30   #8
MaxDembo81
Member
 
Iscritto dal: May 2010
Messaggi: 161
testiamolo
MaxDembo81 è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2011, 15:58   #9
MaxDembo81
Member
 
Iscritto dal: May 2010
Messaggi: 161
funzionare funziona

Mi spieghi come ci sei arrivato?
MaxDembo81 è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2011, 16:45   #10
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Ho scritto la logica nel primo post.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 14-01-2011, 05:49   #11
goldorak
Senior Member
 
Iscritto dal: Apr 2003
Messaggi: 16462
Quote:
Originariamente inviato da MaxDembo81 Guarda i messaggi
Salve a tutti,
non ricordo/non riesco a trasformare un semplicissimo algoritmo da ricorsivo a iterativo.
L'algoritmo è il seguente

Codice:
 double s(int i, int N, int A{
if (i == 0 ) return 0;
if (i == 1 ) return 1;
else return 2*N*s(i-1,N,A) + (A-N*N)*s(i-2,N,A);}
Com'era la regola generale?
E come lo si traduce questo?

Grazie e scusate la nabbanza
A e N sono parametri e non cambiano nelle varie chiamate ricorsive, quindi la tua funzione s dipende solo da i.

caso base : s(0) =0, s(1)=1
caso ricorsivo : s(n) = 2Ns(i-1)+(A-N^2)s(i-2)

quindi si vede che s(n) dipende soltanto dai due valori immediatamente precedenti s(i-1) e s(i-2). Nell'algoritmo iterativo sara' sufficiente ricordarsi degli ultimi due valori calcolati per determinare il valore piu' recente.
__________________
MICROSOFT : Violating your privacy is our priority
goldorak è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
Roscosmos: inventario a bordo della ISS ...
Arduino viene acquisita da Qualcomm e ca...
Un razzo spaziale Arianespace Vega C ha ...
Terra Next dà il via a Scale-Up P...
Il veicolo riutilizzabile ESA Space Ride...
Un Mousepad per mirare meglio: uno youtu...
Tokyo Electron sotto accusa: Taiwan cont...
L'ESA sta cercando alternative all'utili...
iliad TOP 250 PLUS e TOP 300 PLUS: valan...
FRITZ! a Sicurezza 2025: connessioni WiF...
I 18enni di oggi non fanno più la...
Super offerte Apple: iPhone 16e a 529€ e...
Torres EVT arriva in Italia con listino ...
Microsoft Flight Simulator 2024 provato ...
Offerte Amazon ancora attive: Kindle, Fi...
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:40.


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