Comment inverser un tableau en C++, Python et JavaScript
Un tableau est une collection d'éléments stockés dans des emplacements de mémoire contigus. L'inversion d'un tableau est l'une des opérations les plus courantes à effectuer sur un tableau. Dans cet article, vous apprendrez à écrire votre propre implémentation d'inversion d'un tableau en utilisant des approches itératives et récursives.
Approche itérative pour inverser un tableau
Énoncé du problème
On vous donne un tableau arr . Vous devez inverser les éléments du tableau, puis imprimer le tableau inversé. Vous devez implémenter cette solution à l'aide de boucles.
Exemple 1 : Soit arr = [45, 12, 67, 63, 9, 23, 74]
Arr inversé = [74, 23, 9, 63, 67, 12, 45]
Ainsi la sortie est : 74 23 9 63 67 12 45.
Exemple 2 : Soit arr = [1, 2, 3, 4, 5, 6, 7, 8]
Arr inversé = [8, 7, 6, 5, 4, 3, 2, 1]
Ainsi la sortie est : 8 7 6 5 4 3 2 1.
Approche pour inverser un tableau à l'aide de boucles
Vous pouvez inverser les éléments d'un tableau à l'aide de boucles en suivant l'approche ci-dessous :
- Initialisez les variables d'index "i" et "j" de sorte qu'elles pointent respectivement sur le premier (0) et le dernier (sizeOfArray – 1) index du tableau.
- Dans une boucle, échangez l'élément à l'index i avec l'élément à l'index j.
- Incrémentez la valeur de i de 1 et décrémentez la valeur de j de 1.
- Exécutez la boucle jusqu'à ce que i < sizeOfArray/2.
Programme C++ pour inverser un tableau à l'aide de boucles
Vous trouverez ci-dessous le programme C++ pour inverser un tableau à l'aide de boucles :
// C++ program to reverse the elements of an array using loops
#include <iostream>
using namespace std;
void reverseArr(int arr[], int size)
{
for(int i=0, j=size-1; i<size/2; i++, j--)
{
swap(arr[i], arr[j]);
}
}
void printArrayElements(int arr[], int size)
{
for(int i=0; i<size; i++)
{
cout << arr[i] << " ";
}
cout << endl;
}
// Driver Code
int main()
{
int arr[] = {45, 12, 67, 63, 9, 23, 74};
int size = sizeof(arr)/sizeof(arr[0]);
// Printing the original array
cout << "Original Array: " << endl;
printArrayElements(arr, size);
// Reversing the array
reverseArr(arr, size);
// Printing the reversed array
cout << "Reversed array: " << endl;
printArrayElements(arr, size);
return 0;
}
Production:
Original Array:
45 12 67 63 9 23 74
Reversed array:
74 23 9 63 67 12 45
Programme Python pour inverser un tableau à l'aide de boucles
Vous trouverez ci-dessous le programme Python pour inverser un tableau à l'aide de boucles :
# Python program to reverse the elements of a list using loops
def reverseList(arr, size):
i = 0
j = size-1
while i<size/2:
arr[i], arr[j] = arr[j], arr[i]
i = i + 1
j = j - 1
def printListElements(arr, size):
for i in range(size):
print(arr[i], end=" ")
print()
# Driver Code
arr = [45, 12, 67, 63, 9, 23, 74]
size = len(arr)
# Printing the original array
print("Original Array:")
printListElements(arr, size)
# Reversing the array
reverseList(arr, size)
# Printing the reversed array
print("Reversed Array:")
printListElements(arr, size)
Production:
Original Array:
45 12 67 63 9 23 74
Reversed array:
74 23 9 63 67 12 45
Programme JavaScript pour inverser un tableau à l'aide de boucles
Vous trouverez ci-dessous le programme JavaScript pour inverser un tableau à l'aide de boucles :
// JavaScript program to reverse the elements of an array using loops
function reverseArr(arr, size) {
for(let i=0, j=size-1; i<(size)/2; i++, j--) {
[arr[i], arr[j]] = [arr[j], arr[i]];
}
}
function printArrayElements(arr, size) {
for(let i=0; i<size; i++) {
document.write(arr[i] + " ");
}
document.write("<br>");
}
// Driver Code
var arr = [45, 12, 67, 63, 9, 23, 74];
var size = arr.length;
// Printing the original array
document.write("Original Array: " + "<br>");
printArrayElements(arr, size);
// Reversing the array
reverseArr(arr, size);
// Printing the reversed array
document.write("Reversed Array: " + "<br>");
printArrayElements(arr, size);
Production:
Original Array:
45 12 67 63 9 23 74
Reversed array:
74 23 9 63 67 12 45
Approche récursive pour inverser un tableau
Énoncé du problème
On vous donne un tableau arr . Vous devez inverser les éléments du tableau, puis imprimer le tableau inversé. Vous devez implémenter cette solution en utilisant la récursivité.
Exemple 1 : Soit arr = [45, 12, 67, 63, 9, 23, 74]
Arr inversé = [74, 23, 9, 63, 67, 12, 45]
Ainsi la sortie est de 74 23 9 63 67 12 45.
Exemple 2 : Soit arr = [1, 2, 3, 4, 5, 6, 7, 8]
Arr inversé = [8, 7, 6, 5, 4, 3, 2, 1]
Ainsi la sortie est 8 7 6 5 4 3 2 1.
Approche pour inverser un tableau à l'aide de la récursivité
Vous pouvez inverser les éléments d'un tableau à l'aide de la récursivité en suivant l'approche ci-dessous :
- Initialisez le début et la fin des variables d'index de telle sorte qu'elles pointent respectivement sur le premier (0) et le dernier (sizeOfArray – 1) index du tableau.
- Échangez l'élément au début de l'index avec l'élément à la fin de l'index.
- Appelez récursivement la fonction reverse. Dans les paramètres de la fonction reverse, incrémenter la valeur de start de 1 et décrémenter la valeur de end de 1.
- Arrêtez la récursivité lorsque la valeur de la variable de début est supérieure ou égale à la valeur de la variable de fin .
Programme C++ pour inverser un tableau à l'aide de la récursivité
Vous trouverez ci-dessous le programme C++ pour inverser un tableau à l'aide de la récursivité :
// C++ program to reverse an array using recursion
#include <iostream>
using namespace std;
void reverseArr(int arr[], int start, int end)
{
if (start >= end)
{
return;
}
swap(arr[start], arr[end]);
reverseArr(arr, start+1, end-1);
}
void printArrayElements(int arr[], int size)
{
for(int i=0; i<size; i++)
{
cout << arr[i] << " ";
}
cout << endl;
}
// Driver Code
int main()
{
int arr[] = {45, 12, 67, 63, 9, 23, 74};
int size = sizeof(arr)/sizeof(arr[0]);
// Printing the original array
cout << "Original Array: " << endl;
printArrayElements(arr, size);
// Reversing the array
reverseArr(arr, 0, size-1);
// Printing the reversed array
cout << "Reversed array: " << endl;
printArrayElements(arr, size);
return 0;
}
Production:
Original Array:
45 12 67 63 9 23 74
Reversed array:
74 23 9 63 67 12 45
Programme Python pour inverser un tableau à l'aide de la récursivité
Vous trouverez ci-dessous le programme Python permettant d'inverser un tableau à l'aide de la récursivité :
# Python program to reverse an array using recursion
def reverseList(arr, start, end):
if start >= end:
return
arr[start], arr[end] = arr[end], arr[start]
reverseList(arr, start+1, end-1)
def printListElements(arr, size):
for i in range(size):
print(arr[i], end=" ")
print()
# Driver Code
arr = [45, 12, 67, 63, 9, 23, 74]
size = len(arr)
# Printing the original array
print("Original Array:")
printListElements(arr, size)
# Reversing the array
reverseList(arr, 0, size-1)
# Printing the reversed array
print("Reversed Array:")
printListElements(arr, size)
Production:
Original Array:
45 12 67 63 9 23 74
Reversed array:
74 23 9 63 67 12 45
Programme JavaScript pour inverser un tableau à l'aide de la récursivité
Vous trouverez ci-dessous le programme JavaScript pour inverser un tableau à l'aide de la récursivité :
// JavaScript program to reverse an array using recursion
function reverseArr(arr, start, end)
{
if (start >= end)
{
return;
}
[arr[start], arr[end]] = [arr[end], arr[start]];
reverseArr(arr, start+1, end-1);
}
function printArrayElements(arr, size)
{
for(let i=0; i<size; i++)
{
document.write(arr[i] + " ");
}
document.write("<br>");
}
// Driver Code
var arr = [45, 12, 67, 63, 9, 23, 74];
let size = arr.length;
// Printing the original array
document.write("Original Array: " + "<br>");
printArrayElements(arr, size);
// Reversing the array
reverseArr(arr, 0, size-1);
// Printing the reversed array
document.write("Reversed Array: " + "<br>");
printArrayElements(arr, size);
Production:
Original Array:
45 12 67 63 9 23 74
Reversed array:
74 23 9 63 67 12 45
Utiliser la récursivité pour résoudre les problèmes
Une fonction récursive est une fonction qui s'appelle elle-même. En récursivité, un problème est résolu en décomposant les problèmes en versions plus petites et plus simples d'eux-mêmes.
Les avantages de la récursivité sont nombreux : le code récursif est plus court qu'un code itératif, il peut être utilisé pour résoudre les problèmes qui sont naturellement récursifs, il peut être utilisé dans les évaluations infixe, préfixe, postfixe, la récursivité réduit le temps nécessaire à l'écriture et code de débogage, etc.
La récursion est un sujet de prédilection des intervieweurs dans les entretiens techniques. Vous devez connaître la récursivité et savoir comment l'utiliser lors de l'écriture de code pour être le programmeur le plus efficace possible.