L'autre jour, mon professeur de chimie nous expliquait la notation scientifique (en utilisant un petit nombre et en la multipliant par des puissances de dix pour exprimer plus facilement les grands nombres), ce qui m'a ramené quelques années en arrière lorsque je l'ai apprise. Après avoir appris les bases, nous avions fait un tas de questions mathématiques typiques, dont certaines étaient les suivantes:
Représenter les éléments suivants en notation scientifique:
a) 50000000
b) 120000000000000
c) 900000000000000000000000000000000000000000
d) pi ^ e ^ i ^ j ^ k ^ std :: vector
...
z) 200
...
Et j'ai pensé: "Quoi? On nous a dit que la notation scientifique était utilisée pour rendre l'écriture de grands nombres plus efficace, mais certains cas ne sont pas du tout plus efficaces!"
Considérez le nombre
300
et sa représentation en notation scientifique:
3x10^2
Quoi, la version scientifiquement notée prend en fait plus de place? Nous ne pouvons pas avoir ça maintenant, n'est-ce pas? (L'espace d'écran est précieux.)
Nous pourrions nous déterminer s'il est plus efficace d'écrire un nombre en notation scientifique ou non, ou ...
Tâche
Votre programme ou fonction doit prendre en entrée un seul nombre positif n
de taille arbitraire (jusqu'à ce que votre langue prend en charge) et produire la version scientifiquement notée du nombre.
Cependant, si le nombre d'origine n
, après suppression des zéros de fin et de la décimale de fin, prend moins ou la même quantité de caractères à afficher que sa version scientifiquement notée, vous devez n
plutôt produire ce nombre d'origine .
Votre code doit être aussi court que possible car la sortie doit également être aussi courte que possible.
Caractéristiques
La notation scientifique efficace est définie comme suit:
bx10^e
b
est le nombre d'entrée divisé de manière appropriée par des puissances de 10 telles que 1 <= b < 10
. Ce nombre doit avoir tous les zéros de fin (et le point décimal si nécessaire) supprimés, mais doit avoir la précision du nombre d'origine (jusqu'à la limite du point décimal dans votre langue, bien sûr). C'est-à-dire 90000
devient 9
, 13.500
devient 1.35
, 0.000675
devient 6.75
etc. Si ce nombre contient plus de décimales que votre langue ne peut en gérer, il doit être arrondi à ce nombre maximal de décimales.
e
est l'exposant auquel dix est élevé de telle sorte que n = b x 10^e
(rappelez-vous que ce nombre doit être négatif si n
est inférieur à 1). Ce nombre ne doit pas avoir de zéros à la fin ni de décimale (principalement parce que s'il ne s'agit pas d'un entier, quelque chose ne va pas ...).
Les caractères x10^
doivent rester tels quels dans la chaîne entre b
et e
.
Cas de test
Input -> output
1 -> 1
20 -> 20
3000000 -> 3x10^6
400000 -> 400000
0.008093 -> 0.008093
0.007835000000000 -> 0.007835
0.000003000000 -> 3x10^-6
0.00000065 -> 6.5x10^-7
0 -> 0
Notation
C'est le code-golf , donc le code le plus court en octets gagne.
Autres règles et clarification
- Les zéros de fin (et / ou la décimale de fin) ne sont pas comptés dans le nombre de caractères du numéro d'entrée d'origine
n
. Gardez cela à l'esprit pour les cas tels que le cas de test 6 - Vous pouvez supposer que si le nombre d'entrée est inférieur à 1, il commencera toujours par un 0 en place pour le chiffre des (comme dans les cas de test 5-8).
- Le numéro d'entrée ne sera jamais négatif
- Les fonctionnalités intégrées qui rendent ce défi trivial et les failles standard sont interdites
- Une nouvelle ligne de fin dans la sortie est OK
EDIT
Merci à user81655 d'avoir signalé les cas de test 7 et 8 avec des pouvoirs incorrects de dix. J'ai maintenant corrigé ces problèmes, assurez-vous que votre code les évalue correctement.
e
9000 -> 9e3
x10^
. Et ce serait un peu de retravailler sur la question, qui je ne pense pas que ce soit approprié maintenant qu'il est affiché
pi^e^i^j^k^std::vector
serait la sortie d'entrée ?