CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

Récursion en C

stuart4
stuart4
Niveau 5
26 mars 2022 à 16:17:20

Bonjour a tous j'ai du mal a comprendre la récursion lorsque plusieurs appels a la fonction sont fait.

par exemple je comprends ceci :


void fun(int n)
{
    if (n <= 0)
    {
        return;
    }
    n -= 1;
    fun(n);
}

On appel a fun jusqu'a ce n soit plus petit ou égal a 0 mais comment cela fonctionne-t-il lorsque l'on appelle la fonction 2x ?


void fun(int n)
{
    if (n <= 0)
    {
        return;
    }
    n -= 1;
    fun(n);
    fun(n - 1);
}

Ici de ce que j'ai compris fun(n - 1) ne devrais jamais être éxécutée car fun(n) aura déja été appelée plusieurs fois et n sera plus petit ou égal a 0 cepandant ca n'a pas l'air de fonctionner comme ca et le 2ème appel a fun() se fait quand même.

Quelqu'un pourrai-t-il m'expliquer svp ?

godrik
godrik
Niveau 30
26 mars 2022 à 16:24:58

depile l'execution a la main pour n=4 et tu comprendra ce qu'il se passe.

PS: changer la valeure d'un parametre de fonction en general rends les codes plus difficile a lire.

stuart4
stuart4
Niveau 5
26 mars 2022 à 16:30:35

Que signfie "depile" ? Et j'ai changer la valeure pour l'exemple.

godrik
godrik
Niveau 30
26 mars 2022 à 16:38:21

Ce que je veux dire est execute le code a la main sur une feuille de papier. La recursivite est quelquechose que les etudiants ne comprennent pas en regardant le code. Il faut suivre le flot d'execution du code attentivement pour comprendre ce qu'il se passe.

stuart4
stuart4
Niveau 5
26 mars 2022 à 16:40:11

C'est justement comme ca que je suis arrivé a la conclusion que le deuxième appel a fun() ne se ferai pas ?

Jacana
Jacana
Niveau 10
26 mars 2022 à 16:41:37

Tu crois modifier la valeur de n mais c'est une variable locale à ta fonction. À chaque appel de fonction la lettre n désigne une variable différente.

void fun(int n)
{
    if (n <= 0)
    {
        return;
    }
    fun(n - 1);
    fun(n - 2);
}

Ta deuxième fonction est équivalente à ça.

Message édité le 26 mars 2022 à 16:43:23 par Jacana
stuart4
stuart4
Niveau 5
26 mars 2022 à 16:51:15

Ah oui c'est vrai ce sont des variables locales

godrik
godrik
Niveau 30
26 mars 2022 à 16:51:45

Ou encore:

void f (int n) {
  n = n-1;
}

void g() {
  int n = 2;
  f(n);
  print(n);
}

Tu penses que g affiche quoi?

stuart4
stuart4
Niveau 5
26 mars 2022 à 16:56:16

Il affiche 2 car le n dans est une copie de l'agument que l'on passe a f

stuart4
stuart4
Niveau 5
26 mars 2022 à 16:56:50

il aurai fallu passer l'addresse de n pour que g affiche 1

stuart4
stuart4
Niveau 5
26 mars 2022 à 16:59:06

Par contre je ne comprends toujours pas pourquoi la 2eme fonction s'exécute ?

godrik
godrik
Niveau 30
26 mars 2022 à 17:02:33

fait l'execution a la main de la fonction et partage une photo.

stuart4
stuart4
Niveau 5
26 mars 2022 à 17:13:16

https://image.noelshack.com/fichiers/2022/12/6/1648311192-img-20220326-171027-1.jpg

godrik
godrik
Niveau 30
26 mars 2022 à 18:00:12

L'execution est temporelle, il te manque plein d'etape la. donne moi 30 minute pour construire l'execution.

stuart4
stuart4
Niveau 5
26 mars 2022 à 18:02:31

D'accord merci

godrik
godrik
Niveau 30
26 mars 2022 à 18:15:27

https://image.noelshack.com/fichiers/2022/12/6/1648314918-rec-1.png

godrik
godrik
Niveau 30
26 mars 2022 à 18:17:56

J'ai construit le debut de l'execution pour f(3) jusqua ce que le deuxieme appel a f par f(3) arrive. j'ai arrete en chemin parceque ca devient chiant a faire, et j'etait a court de place sur la page.

Quand tu as un appel de fonctino, dans la pile d'execution tu as le pointeur d'execution sur l'instruction en court. Ici je la represente avec le nom de la fonction et le numero de ligne. Et tu as aussi les valeures des variables qui sont dans la pile. ici il n'y a que la variable n.

Sapokan
Sapokan
Niveau 4
26 mars 2022 à 20:04:54

C'est plus facile à comprendre quand la fonction récursive renvoie quelque chose.

int fun(int n)
{
    if (n <= 0)
        return 0;
    return n + fun(n-1);
}

Disons que tu appelles fun(3)

fun(3) renvoie 3 + fun(2)
fun(2) renvoie 2 + fun(1)
fun(1) renvoie 1 + fun(0)
fun(0) renvoie 0

soit
fun(3) renvoie 3 + 2 + 1 + 0

stuart4
stuart4
Niveau 5
26 mars 2022 à 20:47:59

Merci pour vos réponse c'est une des thématiques les plus complexe selon moi et ca ne doit pas être facile a expliquer non plus

Sous forums
  • Aide à l'achat Mac
  • Steam Deck
  • Création de sites web
  • Création de Jeux
  • Linux
  • Programmation
  • Internet
  • Macintosh
  • Hardware
La vidéo du moment