Table des matières
Grammaire
Algorithme
Méthode
Méthode 1 : Utiliser les fonctions intégrées
Exemple
Sortie
Explication
Méthode 2 : Ne pas utiliser les fonctions intégrées
Conclusion
Maison développement back-end C++ Minimiser le produit des plus grands nombres dans deux tableaux en utilisant le swap

Minimiser le produit des plus grands nombres dans deux tableaux en utilisant le swap

Aug 29, 2023 pm 07:21 PM
数组 produit minimisation des échanges

Minimiser le produit des plus grands nombres dans deux tableaux en utilisant le swap

La manipulation de la structure des données est désormais un aspect important du développement réussi de solutions dans la programmation et l'informatique modernes. Cela est dû à la complexité croissante présentée par ces structures au fil du temps. Un exemple consiste à effectuer une opération d'échange pour minimiser la somme des plus grands nombres contenus dans deux tableaux, réduisant ainsi leur valeur globale. Dans cet article, nous discutons de deux manières d'accomplir ces tâches en utilisant C++, tout en reconnaissant les avantages et les inconvénients de chaque approche en fonction de différentes perspectives.

Grammaire

Afin de comprendre efficacement les méthodes et les codes du langage de programmation C++, nous devons avoir une solide compréhension de la syntaxe de base. Cela signifie examiner de plus près les éléments pertinents pour le sujet traité.

Arrays: int arrayName[size];
Sorting: sort(arrayName, arrayName + size);
Swap: swap(arrayName1[index], arrayName2[index]);
Function Declaration: int functionName(type variableName);
Copier après la connexion

Algorithme

Une façon de réduire le produit des plus grands nombres dans deux tableaux consiste à utiliser un algorithme commun pour échanger leurs éléments. Pour illustrer cette approche, considérons l'exemple suivant -

  • Accepte ou initialise deux tableaux.

  • Triez deux tableaux.

  • Trouvez le plus grand élément de chaque tableau.

  • Si le plus grand élément du premier tableau est plus important que le plus grand élément du deuxième tableau, échangez.

  • Répétez les étapes 3 et 4 jusqu'à ce que nous ne puissions plus minimiser le produit.

Méthode

Maintenant, discutons de deux méthodes différentes −

Méthode 1 : Utiliser les fonctions intégrées

  • La première méthode consiste à utiliser les fonctions de tri et d'échange intégrées en C++.

  • Initialisez ou saisissez deux tableaux.

  • L'utilisation de la fonction sort() est un outil utile pour trier le contenu d'un tableau par ordre croissant.

  • Trouvez le plus grand élément (dernier élément après le tri) dans deux tableaux.

  • Si le plus grand élément du premier tableau est supérieur au plus grand élément du deuxième tableau, utilisez la fonction swap() pour échanger les éléments.

  • Continuez ce processus jusqu'à ce que le produit ne puisse plus être minimisé.

Exemple

#include<bits/stdc++.h>
using namespace std;

void minimizeProduct(int a[], int b[], int n) {
   sort(a, a + n);
   sort(b, b + n);
    
   for (int i = n - 1; i >= 0; --i) {
      if (a[i] > b[i])
         swap(a[i], b[i]);
      else
         break;
   }
    
   cout << "Product of maximums: " << a[n - 1] * b[n - 1] << endl;
}

int main() {
   int a[] = {5, 7, 9, 3, 6};
   int b[] = {1, 2, 6, 8, 0};
   int n = sizeof(a)/sizeof(a[0]);

   minimizeProduct(a, b, n);
    
   return 0;
}
Copier après la connexion

Sortie

Product of maximums: 72
Copier après la connexion
Copier après la connexion
La traduction chinoise de

Explication

est :

Explication

Cette méthode utilise la directive #include pour ajouter des bibliothèques avant d'exécuter la tâche. Définir l'espace de noms std au début simplifie l'appel des fonctions de bibliothèque standard et évite les longues instructions. Entrez la fonction minimiserProduct, qui inclut les deux tableaux d'entrée et leurs tailles comme paramètres.

Ensuite, il trie ces tableaux par ordre croissant à l'aide de la méthode sort() intégrée, puis démarre une boucle for comparant les plus grands éléments du premier et du deuxième tableaux.

Si le plus grand élément du premier tableau est plus grand que le deuxième tableau, échangez les éléments pour vous rapprocher de la solution. Imprimez le produit en utilisant l'élément maximum nouvellement échangé. Les fonctions intégrées telles que sort() et swap() permettent d'y parvenir sans problème. L’appel de minimiseProduct dans main() renvoie 0 pour indiquer le succès.

Méthode 2 : Ne pas utiliser les fonctions intégrées

Cette technique peut apporter des avantages dans les situations où les fonctions intégrées ne sont pas possibles. Au lieu d'utiliser des fonctions de tri et d'échange prédéfinies, nous créons nos variantes personnalisées.

  • Initialisez ou saisissez deux tableaux.

  • Implémentez une fonction de tri pour trier deux tableaux par ordre croissant.

  • Trouvez le plus grand élément (dernier élément après le tri) dans deux tableaux.

  • Si le plus grand élément du premier tableau est supérieur au plus grand élément du deuxième tableau, utilisez une fonction d'échange personnalisée pour échanger les éléments.

  • Répétez jusqu'à ce que vous ne puissiez plus réduire le produit.

Exemple

#include<iostream>
using namespace std;

void sortArray(int arr[], int n) {
   for(int i = 0; i < n; ++i) {
      for(int j = i+1; j < n; ++j) {
         if(arr[i] > arr[j]) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
         }
      }
   }
}

void minimizeProduct(int a[], int b[], int n) {
   sortArray(a, n);
   sortArray(b, n);
    
   for (int i = n - 1; i >= 0; --i) {
      if (a[i] > b[i]) {
         int temp = a[i];
         a[i] = b[i];
         b[i] = temp;
      } else {
         break;
      }
   }
    
   cout << "Product of maximums: " << a[n - 1] * b[n - 1] << endl;
}

int main() {
   int a[] = {5, 7, 9, 3, 6};
   int b[] = {1, 2, 6, 8, 0};
   int n = sizeof(a)/sizeof(a[0]);

   minimizeProduct(a, b, n);
    
   return 0;
}
Copier après la connexion

Sortie

Product of maximums: 72
Copier après la connexion
Copier après la connexion
La traduction chinoise de

Explication

est :

Explication

Dans une autre approche, nous abandonnons l'utilisation des fonctions intégrées et implémentons plutôt les opérations de tri et d'échange manuellement. Nous écrivons d'abord une nouvelle fonction appelée « sortArray » qui utilise des boucles for imbriquées pour comparer et échanger les éléments dans l'ordre souhaité lorsqu'un tableau est donné en entrée. Dans 'minimizeProduct', les deux tableaux donnés sont triés de la même manière avant de commencer l'itération, puis nous commençons à itérer à partir de l'extrémité droite et échangeons les éléments correspondants si nécessaire - uniquement à n'importe quelle étape de l'itération, dans le premier tableau. Les éléments de sont échangés uniquement s'ils sont plus grands dans le sens de la colonne que les éléments du deuxième tableau ; enfin, le produit des valeurs maximales est obtenu grâce à ce processus et imprimé sur la console de sortie en tant que résultat. Dans 'main()', cette opération 'minimiser le produit' est appliquée en passant des valeurs prédéfinies via deux tableaux préexistants.

Conclusion

La valeur entière maximale dans deux tableaux spécifiés peut être considérablement réduite en utilisant un programme C++ selon la méthode détaillée ici. Cette réduction est obtenue grâce à des techniques d'échange d'éléments qualifiées. De plus, cette approche permet une compréhension plus approfondie des multiples stratégies de manipulation des tableaux : elle met en évidence la manière dont les fonctions personnalisées se complètent lorsqu'elles sont utilisées avec des options prédéfinies. Il est important de se rappeler que déterminer quelle méthode est la plus appropriée dépend principalement des contraintes et du potentiel de calcul global de chaque problème. Sur la base de ces considérations, il est important de ne pas succomber à la frustration lorsque vous travaillez pour améliorer vos compétences en codage.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comment supprimer les éléments en double du tableau PHP à l'aide de la boucle foreach ? Comment supprimer les éléments en double du tableau PHP à l'aide de la boucle foreach ? Apr 27, 2024 am 11:33 AM

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.

L'art de PHP Array Deep Copy : utiliser différentes méthodes pour obtenir une copie parfaite L'art de PHP Array Deep Copy : utiliser différentes méthodes pour obtenir une copie parfaite May 01, 2024 pm 12:30 PM

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.

Inversion des valeurs clés du tableau PHP : analyse comparative des performances de différentes méthodes Inversion des valeurs clés du tableau PHP : analyse comparative des performances de différentes méthodes May 03, 2024 pm 09:03 PM

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.

Meilleures pratiques pour la copie approfondie des tableaux PHP : découvrez des méthodes efficaces Meilleures pratiques pour la copie approfondie des tableaux PHP : découvrez des méthodes efficaces Apr 30, 2024 pm 03:42 PM

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.

Pratique du tri multidimensionnel des tableaux PHP : des scénarios simples aux scénarios complexes Pratique du tri multidimensionnel des tableaux PHP : des scénarios simples aux scénarios complexes Apr 29, 2024 pm 09:12 PM

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.

Application de la fonction de regroupement de tableaux PHP dans le tri des données Application de la fonction de regroupement de tableaux PHP dans le tri des données May 04, 2024 pm 01:03 PM

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.

Algorithme de fusion et de déduplication de tableaux PHP : solution parallèle Algorithme de fusion et de déduplication de tableaux PHP : solution parallèle Apr 18, 2024 pm 02:30 PM

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.

Le rôle de la fonction de regroupement de tableaux PHP dans la recherche d'éléments en double Le rôle de la fonction de regroupement de tableaux PHP dans la recherche d'éléments en double May 05, 2024 am 09:21 AM

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.

See all articles