


Réorganiser un tableau pour que la somme des produits de paires d'éléments consécutives soit minimale, écrit en C++
Nous avons un tableau de types entiers positifs, en supposant qu'il s'agit de arr[], de n'importe quelle taille. La tâche consiste à réorganiser le tableau de telle sorte que lorsque nous multiplions un élément avec ses éléments adjacents, puis ajoutons tous les éléments résultants, la plus petite somme soit renvoyée.
Regardons différentes situations d'entrée et de sortie :
Entrée - int arr[] = {2, 5, 1, 7, 5, 0, 1, 0}
Sortie - Réorganiser le tableau pour minimiser la somme, c'est-à-dire le produit d'une paire d'éléments consécutifs est : 7 0 5 0 5 1 2 1
Explication- Nous avons un tableau entier de taille 8. Nous allons maintenant réorganiser le tableau, c'est-à-dire 7 0 5 0 5 1 2 1. Nous vérifierons si la somme minimale est renvoyée, c'est-à-dire 7 * 0 + 5 * 0 + 5 * 1 + 2 * 1 = 0 + 0 + 5 + 2 = 7.
Entrée - int arr[] = {1, 3, 7, 2, 4, 3}
Sortie - Réorganiser le tableau pour minimiser la somme, c'est-à-dire que le produit d'une paire consécutive d'éléments est : 7 1 4 2 3 3
Explication- Nous avons un tableau d'entiers de taille 6. Nous allons maintenant réorganiser le tableau, c'est-à-dire 7 1 4 2 3 3. Nous vérifierons si la somme minimale est renvoyée, c'est-à-dire 7 * 1 + 4 * 2 + 3 * 3 = 7 + 8 + 9 = 24.
La méthode utilisée dans le programme suivant est la suivante :
Saisissez un tableau de type entier et calculez la taille du tableau.
Triez le tableau en utilisant la méthode de tri de C++ STL, en passant le tableau et la taille du tableau à la fonction de tri.
Déclarez une variable entière et définissez-la comme valeur de retour de la fonction appelante.
À l'intérieur de la fonction Rearrange_min_sum(arr, size)
Créez une variable, disons, de type « pair » et « impair » qui stocke des variables entières.
Déclarez une variable comme temp et total et initialisez-la avec 0.
Démarrez la boucle FOR de i à 0 jusqu'à ce que i soit inférieur à la taille. À l'intérieur de la boucle, vérifiez SI i est inférieur à size/2 puis appuyez sur arr[i] vers. vecteur impair ELSE, poussez arr[i] vers vecteur pair
Appelez la méthode de tri en passant even.begin(), even.end() et Greater
(). Démarrez la boucle FOR à partir de i à 0 jusqu'à ce que je soit inférieur à even.size(). Dans la boucle, définissez arr[temp++] sur pair[j], arr[temp++] sur impair[j] et total sur total + pair[j] * impair[j]
Retour total
Imprimez le résultat.
Exemple
#include <bits/stdc++.h> using namespace std; int Rearrange_min_sum(int arr[], int size){ vector<int> even, odd; int temp = 0; int total = 0; for(int i = 0; i < size; i++){ if (i < size/2){ odd.push_back(arr[i]); } else{ even.push_back(arr[i]); } } sort(even.begin(), even.end(), greater<int>()); for(int j = 0; j < even.size(); j++){ arr[temp++] = even[j]; arr[temp++] = odd[j]; total += even[j] * odd[j]; } return total; } int main(){ int arr[] = { 2, 5, 1, 7, 5, 0, 1, 0}; int size = sizeof(arr)/sizeof(arr[0]); //sort an array sort(arr, arr + size); //call function int total = Rearrange_min_sum(arr, size); cout<<"Rearrangement of an array to minimize sum i.e. "<<total<<" of product of consecutive pair elements is: "; for(int i = 0; i < size; i++){ cout << arr[i] << " "; } return 0; }
Sortie
Si nous exécutons le code ci-dessus, il générera la sortie suivante
Rearrangement of an array to minimize sum i.e. 7 of product of consecutive pair elements is: 7 0 5 0 5 1 2 1
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

La méthode d'utilisation d'une boucle foreach pour supprimer les éléments en double d'un tableau PHP est la suivante : parcourez le tableau, et si l'élément existe déjà et que la position actuelle n'est pas la première occurrence, supprimez-le. Par exemple, s'il existe des enregistrements en double dans les résultats de la requête de base de données, vous pouvez utiliser cette méthode pour les supprimer et obtenir des résultats sans enregistrements en double.

Les méthodes de copie approfondie de tableaux en PHP incluent : l'encodage et le décodage JSON à l'aide de json_decode et json_encode. Utilisez array_map et clone pour créer des copies complètes des clés et des valeurs. Utilisez Serialize et Unsérialize pour la sérialisation et la désérialisation.

La comparaison des performances des méthodes de retournement des valeurs de clé de tableau PHP montre que la fonction array_flip() fonctionne mieux que la boucle for dans les grands tableaux (plus d'un million d'éléments) et prend moins de temps. La méthode de la boucle for consistant à retourner manuellement les valeurs clés prend un temps relativement long.

La meilleure pratique pour effectuer une copie complète d'un tableau en PHP consiste à utiliser json_decode(json_encode($arr)) pour convertir le tableau en chaîne JSON, puis à le reconvertir en tableau. Utilisez unserialize(serialize($arr)) pour sérialiser le tableau en chaîne, puis désérialisez-le en un nouveau tableau. Utilisez RecursiveIteratorIterator pour parcourir de manière récursive des tableaux multidimensionnels.

La fonction array_group_by de PHP peut regrouper des éléments dans un tableau en fonction de clés ou de fonctions de fermeture, renvoyant un tableau associatif où la clé est le nom du groupe et la valeur est un tableau d'éléments appartenant au groupe.

Le tri des tableaux multidimensionnels peut être divisé en tri sur une seule colonne et en tri imbriqué. Le tri sur une seule colonne peut utiliser la fonction array_multisort() pour trier par colonnes ; le tri imbriqué nécessite une fonction récursive pour parcourir le tableau et le trier. Les cas pratiques incluent le tri par nom de produit et le tri composé par volume de ventes et prix.

L'algorithme de fusion et de déduplication de tableaux PHP fournit une solution parallèle, divisant le tableau d'origine en petits blocs pour un traitement parallèle, et le processus principal fusionne les résultats des blocs à dédupliquer. Étapes algorithmiques : divisez le tableau d'origine en petits blocs également alloués. Traitez chaque bloc pour la déduplication en parallèle. Fusionnez les résultats du bloc et dédupliquez à nouveau.

La fonction array_group() de PHP peut être utilisée pour regrouper un tableau par une clé spécifiée afin de rechercher les éléments en double. Cette fonction fonctionne selon les étapes suivantes : Utilisez key_callback pour spécifier la clé de regroupement. Utilisez éventuellement value_callback pour déterminer les valeurs de regroupement. Comptez les éléments regroupés et identifiez les doublons. Par conséquent, la fonction array_group() est très utile pour rechercher et traiter des éléments en double.
