recherche
Maisondéveloppement back-endC++Maximiser les valeurs manquantes sur une période de temps donnée, au format HH:MM

Maximiser les valeurs manquantes sur une période de temps donnée, au format HH:MM

Sep 07, 2023 pm 05:41 PM
délaiMaximiser les valeurs manquantesformat hh:mm

Maximiser les valeurs manquantes sur une période de temps donnée, au format HH:MM

Représente la chaîne donnée de longueur cinq sous forme d'heure au format HH:MM. La chaîne peut contenir des "?" et nous devons les remplacer par n'importe quel nombre pour que le résultat soit une heure valide et probablement la plus grande possible. De plus, les numéros de chaîne donnés seront valides et le « : » apparaîtra à la position exacte de la chaîne. Nous utiliserons d’abord les méthodes de force brute, puis utiliserons des méthodes efficaces.

Exemple Exemple

Entrez 1

Given string: 12:5?
Output: 12:59
La traduction chinoise de

Explication

est :

Explication

Nous n'avons qu'une seule place à pourvoir et le temps maximum que nous pouvons obtenir est de 12h59.

Entrez 2

Given string: ?0:?9
Output: 20:59
La traduction chinoise de

Explication

est :

Explication

Nous avons ici deux emplacements vides, nous allons d'abord nous concentrer sur la partie heures, nous avons trois options 0, 1 et 2 pour les remplir. Pour la partie minutes nous avons des choix de 0 à 5, pour maximiser nous pouvons remplir 5.

Méthode

Nous avons examiné des exemples, regardons maintenant les différents types de situations auxquelles nous pourrions être confrontés −

  • Nous avons deux parties de la chaîne, la partie heure et la partie minute.

  • La partie heure va de 0 à 23 et la partie minute va de 0 à 59.

  • Il y a plus de situations dans la partie horaire−

    • « x ? » où x peut être 0, 1 et 2. Pour 0, nous pouvons choisir 0 comme meilleur choix, pour 1, nous pouvons choisir 9 comme meilleur choix, et pour 2, nous pouvons choisir 3 comme meilleur choix.

    • '?x', où x peut aller de 0 à 9. Si x est compris entre 0 et 3, on peut le remplacer par 2, sinon 1 sera le meilleur.

    • '??' Puisqu'il faut maximiser, nous le remplaçons par 23.

  • Procès-verbaux des réunions, certains ont d'autres cas −

    • « x ? » où x peut être compris entre 0 et 5. 9 serait notre meilleur choix pour remplacer « ? ».

    • '?x' où x peut être compris entre 0 et 9. 5 serait notre meilleur choix pour remplacer « ? ».

    • "??" car il faut maximiser et ensuite on le remplace par 59.

Jetons un coup d'œil au code qui implémente les étapes ci-dessus -

La traduction chinoise de

Exemple

est :

Exemple

#include <iostream>
using namespace std;
// function to replace hours
string replaceHours(string s){
   if(s[0] == '?' && s[1] == '?'){
      //Both hour characters are '?'
      // replace with the maximum hour we can achieve 
      s[0] = '2';
      s[1] = '3';
   }
   else if(s[0] == '?'){
      // if the second number of hours is in the range 0 to 3
      // replace by 2
      if(s[1] < 4){
         s[0] = '2';
      }
      else{
         s[0] = '1'; // otherwise replace by one 
      }
   }
   else if(s[1] == '?'){
      // if the first character is '2' we can go only upto 3
      if(s[0] == '2'){
         s[1] = '3';
      }
      else{
         s[1] = '9'; // else we can go for 9 
      }
   }
   return s;
}
// function to replace minutes
string replaceMinutes(string s){
   if(s[3] == '?' && s[4] == '?'){
      // both minutes characters are '?'
      // replace with maximum minutes we can acheive 
      s[3] = '5';
      s[4] = '9';
   }
   else if(s[3] == '?'){
      // we can maximum get 5 here 
      s[3] = '5';
   }
   else if(s[4] == '?'){
      // we can get maximum 9 here
      s[4] = '9';
   }
   return s;
}
int main(){
   string str = "2?:3?"; // given string 
   // calling the function for updation of the minutes 
   str = replaceMinutes(str);
   // calling to the function for updation of the hours
   str = replaceHours(str);
   // printing the final answer
   cout<<"The maximum time we can get by replacing ? is: "<< str<<endl;
   return 0;
}

Sortie

The maximum time we can get by replacing ? is: 23:39

Complexité temporelle et spatiale

La complexité temporelle du code ci-dessus est O(1) ou constante car nous n'utilisons aucune boucle ou appel récursif, vérifiant simplement les conditions if-else

La complexité spatiale du code ci-dessus est O(1) car nous n'utilisons aucun espace supplémentaire. De plus, pour cette fonction, la taille de la chaîne que nous transmettons est toujours un 5 fixe.

Remarque : Pour rendre le code plus beau ou plus lisible, vous pouvez utiliser des instructions switch, elles n'affecteront pas la complexité temporelle ou spatiale et rendront la lecture plus efficace.

De plus, le retour en arrière et la revérification sont une solution, mais cela vérifiera chaque cas et n'est pas efficace à mettre en œuvre ici.

Conclusion

Dans ce tutoriel, on nous donne une chaîne qui représente l'heure au format 24 heures. Il y a des "?" dans la chaîne qui doivent être remplacés pour obtenir la durée de validité maximale, et il est garanti que les caractères de la chaîne pointent toujours vers l'heure de validité. Nous avons utilisé une condition if-else et deux fonctions pour remplacer le « ? » par la casse appropriée. Puisque nous n'utilisons aucune boucle ou fonction récursive, la complexité temporelle et spatiale du code ci-dessus est constante.

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
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer
C # vs C: Histoire, évolution et perspectives d'avenirC # vs C: Histoire, évolution et perspectives d'avenirApr 19, 2025 am 12:07 AM

L'histoire et l'évolution de C # et C sont uniques, et les perspectives d'avenir sont également différentes. 1.C a été inventé par Bjarnestrousstrup en 1983 pour introduire une programmation orientée objet dans le langage C. Son processus d'évolution comprend plusieurs normalisations, telles que C 11, introduisant des mots clés automobiles et des expressions de lambda, C 20 introduisant les concepts et les coroutines, et se concentrera sur les performances et la programmation au niveau du système à l'avenir. 2.C # a été publié par Microsoft en 2000. Combinant les avantages de C et Java, son évolution se concentre sur la simplicité et la productivité. Par exemple, C # 2.0 a introduit les génériques et C # 5.0 a introduit la programmation asynchrone, qui se concentrera sur la productivité et le cloud computing des développeurs à l'avenir.

C # vs C: courbes d'apprentissage et expérience du développeurC # vs C: courbes d'apprentissage et expérience du développeurApr 18, 2025 am 12:13 AM

Il existe des différences significatives dans les courbes d'apprentissage de l'expérience C # et C et du développeur. 1) La courbe d'apprentissage de C # est relativement plate et convient au développement rapide et aux applications au niveau de l'entreprise. 2) La courbe d'apprentissage de C est raide et convient aux scénarios de contrôle haute performance et de bas niveau.

C # vs C: programmation et fonctionnalités orientées objetC # vs C: programmation et fonctionnalités orientées objetApr 17, 2025 am 12:02 AM

Il existe des différences significatives dans la façon dont C # et C implémentent et les fonctionnalités de la programmation orientée objet (POO). 1) La définition de classe et la syntaxe de C # sont plus concises et prennent en charge des fonctionnalités avancées telles que LINQ. 2) C fournit un contrôle granulaire plus fin, adapté à la programmation système et aux besoins élevés de performance. Les deux ont leurs propres avantages et le choix doit être basé sur le scénario d'application spécifique.

De XML à C: transformation et manipulation des donnéesDe XML à C: transformation et manipulation des donnéesApr 16, 2025 am 12:08 AM

La conversion de XML en C et la réalisation des opérations de données peuvent être réalisées via les étapes suivantes: 1) Analyser des fichiers XML à l'aide de la bibliothèque TinyxML2, 2) Mappage des données en structure de données de C, 3) à l'aide de la bibliothèque standard C telle que STD :: vector pour les opérations de données. Grâce à ces étapes, les données converties à partir de XML peuvent être traitées et manipulées efficacement.

C # vs C: Gestion de la mémoire et collecte des orduresC # vs C: Gestion de la mémoire et collecte des orduresApr 15, 2025 am 12:16 AM

C # utilise le mécanisme de collecte automatique des ordures, tandis que C utilise la gestion manuelle de la mémoire. 1. Le collecteur des ordures de C # gère automatiquement la mémoire pour réduire le risque de fuite de mémoire, mais peut entraîner une dégradation des performances. 2.C fournit un contrôle de mémoire flexible, adapté aux applications qui nécessitent une gestion des beaux, mais doivent être manipulées avec prudence pour éviter les fuites de mémoire.

Au-delà du battage médiatique: évaluer la pertinence de C aujourd'huiAu-delà du battage médiatique: évaluer la pertinence de C aujourd'huiApr 14, 2025 am 12:01 AM

C a toujours une pertinence importante dans la programmation moderne. 1) Les capacités de fonctionnement matériel et directes en font le premier choix dans les domaines du développement de jeux, des systèmes intégrés et de l'informatique haute performance. 2) Les paradigmes de programmation riches et les fonctionnalités modernes telles que les pointeurs intelligents et la programmation de modèles améliorent sa flexibilité et son efficacité. Bien que la courbe d'apprentissage soit raide, ses capacités puissantes le rendent toujours important dans l'écosystème de programmation d'aujourd'hui.

La communauté C: ressources, soutien et développementLa communauté C: ressources, soutien et développementApr 13, 2025 am 12:01 AM

C Les apprenants et les développeurs peuvent obtenir des ressources et le soutien de Stackoverflow, des cours R / CPP de Reddit, Coursera et EDX, des projets open source sur GitHub, des services de conseil professionnel et CPPCON. 1. StackOverflow fournit des réponses aux questions techniques; 2. La communauté R / CPP de Reddit partage les dernières nouvelles; 3. Coursera et Edx fournissent des cours de C officiels; 4. Projets open source sur GitHub tels que LLVM et Boost Améliorer les compétences; 5. Les services de conseil professionnel tels que Jetbrains et Perforce fournissent un support technique; 6. CPPCON et d'autres conférences aident les carrières

C # vs C: où chaque langue excelleC # vs C: où chaque langue excelleApr 12, 2025 am 12:08 AM

C # convient aux projets qui nécessitent une efficacité de développement élevée et un support multiplateforme, tandis que C convient aux applications qui nécessitent des performances élevées et un contrôle sous-jacent. 1) C # simplifie le développement, fournit une collection de déchets et des bibliothèques de classe riches, adaptées aux applications au niveau de l'entreprise. 2) C permet un fonctionnement de la mémoire directe, adapté au développement de jeux et à l'informatique haute performance.

See all articles

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.

Outils chauds

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

mPDF

mPDF

mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) ​​et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP