Je trouve la récursivité, à part les très simples comme la factorielle, très difficile à comprendre. L'extrait suivant imprime toutes les permutations d'une chaîne. Quelqu'un peut-il m'aider à le comprendre. Quelle est la marche à suivre pour bien comprendre la récursivité.
void permute(char a[], int i, int n)
{
int j;
if (i == n)
cout << a << endl;
else
{
for (j = i; j <= n; j++)
{
swap(a[i], a[j]);
permute(a, i+1, n);
swap(a[i], a[j]);
}
}
}
int main()
{
char a[] = "ABCD";
permute(a, 0, 3);
getchar();
return 0;
}