Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-05-2013, 17:55   #1
luefash
Junior Member
 
Iscritto dal: May 2013
Messaggi: 2
[C] Funzione calcolo frazione continua

Ciao, cerco qualcuno che possa darmi una mano a capire dove ho sbagliato: si tratta di una funzione ricorsiva che implementa un algoritmo per il calcolo della frazione continua. Il risultato che mi da l'output è errato di poco, non riesco proprio a capire dov'è l'errore.

Codice:
#include <stdio.h>


float CalcFrazCont (int n, int arr[], float sum)
  {
    int i;

    while (i <= n)
      {
        i++;
        sum = sum + (1 / CalcFrazCont (i, arr[i], sum));
      }

    return sum;
 
  }  



int main (void)
  {
    int i, n;
    int arr[100];
    float sum; 


    printf ("Inserisci n: ");
    scanf ("%i", &n);

    printf ("Inserisci %i valori: \n", n);
  
  for (i = 1 ; i <= n ; i++)
    { 
      printf ("%i° valore= ", i);
      scanf ("%i", &arr[i]);
    }  

  sum = arr[1];

  printf ("La frazione continua è: %f", CalcFrazCont(n, arr, sum));


  return 0;

  }
Grazie
luefash è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2013, 18:29   #2
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Guarda davvero non ho visto il codice ma ad un primo sguardo la variabile "i" in
Codice:
float CalcFrazCont (int n, int arr[], float sum)
  {
    int i;

    while (i <= n)
      {
        i++;
        sum = sum + (1 / CalcFrazCont (i, arr[i], sum));
      }

    return sum;
 
  }
non è inizializzata
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 15:22   #3
luefash
Junior Member
 
Iscritto dal: May 2013
Messaggi: 2
Grazie per la risposta, hai perfettamente ragione, mi sono confuso con le variabili globali, che da quanto so vengono inzializzate automaticamente a 0 dal compilatore se lasciate non inizializzate all'interno del programma.

Il problema ora è che ponendo i = 0 mi da "segmentation fault" giusto prima del risultato non capisco, cosa devo allocare??
luefash è offline   Rispondi citando il messaggio o parte di esso
Old 07-05-2013, 15:33   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2789
Il passaggio dei parametri nella chiamata ricorsiva è sbagliato
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2013, 15:45   #5
balth@zar
Member
 
Iscritto dal: Jul 2012
Messaggi: 91
Quote:
Originariamente inviato da luefash Guarda i messaggi
Il problema ora è che ponendo i = 0 mi da "segmentation fault" giusto prima del risultato non capisco, cosa devo allocare??
Nella chiamata ricorsiva

Codice:
sum = sum + (1 / CalcFrazCont (i, arr[i], sum));
arr[i] non è un int[] come richiesto dalla funzione, ma il valore dell'intero in posizione i che viene convertito a puntatore con effetti imprevedibili.
balth@zar è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
Commissione UE contro Google: Big G dovr...
Pale eoliche che durano 500 anni grazie ...
Blink Mini Pan-Tilt a 19,99€: la telecam...
Google e Gucci collaborano per degli occ...
Adobe e Anthropic insieme: il nuovo Fire...
Netflix, importanti novità per l'...
Top 7 tech più venduti su Amazon ...
Stop alle app pesanti: Android 17 Beta 4...
Apple Watch Series 11 e SE 3 crollano su...
Opera Browser Connector: ChatGPT e Claud...
Nuova Opel Astra: maturità elettr...
Il film di Call of Duty ha finalmente un...
Tra nuove mappe e modalità: Battl...
Narwal Flow 2 ufficiale: 31000 Pa di asp...
GPT-Rosalind: OpenAI lancia il suo primo...
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: 11:49.


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