Mon devoir est d'écrire un essai martien (voir ci-dessous) entre 729 et 810 mots, inclus. Votre tâche consiste à écrire un programme qui générera l’essai.
Histoire
Au tournant du XXe siècle, la spiritualiste Catherine-Elise Müller aurait communiqué avec des Martiens. Pendant les transes somnambulatoires, elle écrivait des scripts martiens. La psychologue Théodore Flourney a découvert que ses écrits martiens ressemblaient beaucoup à son français natal. Dans son livre "De l'Inde à la planète Mars", il a documenté l'alphabet martien de Catherine.
Ce qui suit est vaguement basé sur cet alphabet avec un mythe étendu.
Description du problème
La langue martienne a 21 lettres, montrées ici à côté de chaque équivalent latin:
Malheureusement, il n'y a pas d'Unicode pour Martian (bien que Mars fasse partie de l'univers), nous sommes donc bloqués avec des caractères latins.
Alors qu'en anglais, nos phonèmes se divisent en deux types principaux (consonnes / voyelles) que nous mappons de manière approximative en lettres, Martian a trois types de lettres:
- Les voyelles: aeimnou
- Les consonnes dures: bcdgkpt
- Les consonnes douces: fhlrsvz
En plus de cela, la langue martienne contient un seul signe de ponctuation - la période.
Un mot martien est un ensemble de 3 à 9 lettres. Tous les mots martiens ont au moins une voyelle, une consonne dure et une consonne douce (quelque soit l'arrangement). Par exemple, fng
, cdaz
, vpi
et pascal
sont des mots martiens.
Une phrase martienne est un ensemble de 3 à 9 mots martiens délimités par des espaces et suivis d'un point.
Un paragraphe martien est un ensemble de 3 à 9 phrases martiennes délimitées par des espaces et suivi d'une nouvelle ligne.
Un essai martien est une collection de paragraphes martiens qui ne contient aucune répétition de mots contigus.
Une répétition de mots contigus est toute construction SS où S est un ensemble de mots contigus. Notez que cette définition ignore les limites des phrases et des paragraphes.
Exemples
Remarque: il y a une nouvelle nouvelle ligne après chaque exemple (car tous les paragraphes martiens se terminent par une nouvelle ligne)
Essai non martien
Lorem ipsum dolor sit amet. quis nostrud exercitation ullamco laboris.
...pour de nombreuses raisons. Cet exemple illustre quelques règles diverses:
- lorem n'est pas un mot martien car il n'a pas de consonnes dures.
- amet n'est pas un mot martien car il n'a pas de consonnes douces. (
m
est une voyelle martienne). - quis n'est pas un mot martien car il n'a pas de consonnes dures
- quis n'est pas un mot martien car q n'est pas une lettre martienne
- l'exercice physique n'est pas un mot martien parce qu'il a plus de 9 lettres
- l'exercice n'est pas un mot martien car x n'est pas une lettre martienne
Essai martien
fng cdaz vpi. pascal a cassé la base. les popplers ont bon goût.
... parce que c'est un paragraphe martien. Le paragraphe martien contient trois phrases martiennes.
Essai non martien
fng cdaz vpi. pascal a cassé la base. règles pascal gratuites.
... puisque free pascal rules.
n'est pas une phrase martienne, parce que ni free
ne rules
sont des mots de Mars, parce qu'ils n'ont pas de consonnes dures.
Essai martien
fng cdaz vpi. pascal a cassé la base. les popplers ont bon goût. cdaz vpi fng. pauses de base pascal. popplers frappent fort. fng cdaz vpi.
... qui contient deux paragraphes martiens. La phrase fng cdaz vpi.
apparaît deux fois, mais c'est parfait.
Essai non martien
les popplers ont un goût de fng. cdaz vpi pascal. cassé fng cdaz vpi. Pascal a brisé les planètes Omicron. base effraie les chèvres. vpi piv vpi.
... parce que la construction fng. cdaz vpi pascal. broke fng cdaz vpi. [nl] pascal broke
est une répétition de mots contigus.
Défi
Votre défi est d’écrire une fonction ou un programme qui n’accepte aucune entrée, ce qui produit en sortie mon devoir; c'est-à-dire que votre programme devrait générer un essai martien entre 729 et 810 mots (inclus). N'oubliez pas que la sortie de votre programme doit être un essai martien valide, mais vous n'avez pas à le générer de manière aléatoire ou différente à chaque fois. Tout ce que vous faites pour générer un essai martien valide compte.
J'ai écrit un programme C ++ pour vérifier les essais que vous êtes autorisé à utiliser.
C'est du code golf. Le code le plus court en octets gagne. Lacunes standard interdites.
Réponses:
05AB1E ,
25242220 octets-2 octets grâce à Emigna (refactor important, merci homme).
Essayez-le en ligne!
Il s'avère que la version de 810 mots est plus courte que la version de 729 mots.
Sortie:
la source
"."
peut être'.
pour 1 octet enregistré.A7£œJðý72ô€¨'.«9ô9£»
pour 20.Jelly ,
28 26 25 2423 octets-1 octet grâce à carusocomputing (remplace le mot
thimble
parabcdefg
)TryItOnline!
Comment?
Donne une liste de toutes les
362880
permutations desseptpremières neuf lettres de l’alphabet anglaisabcdefghi
, qui possèdent toutes les propriétés des mots martiens et sont toutes distinctes, et les formate en un essai utilisant les premiers729
mots.* période
la source
abcdefg
.Ruby,
86 83 8279 octetsL'astuce: imprimer tous les nombres entre 102000000 et 102222222 en base 3
la source
Python 3,
121119 octetsrepl.it
Comment?
Compte à rebours de
i=729
et obtient une liste des lettres de la ième permutation de'thimble'
comme prochain mot martien distinct (list(permutations('thimble'))[i]
).Évite
''.join(...)
d'utiliser un*expression
pour décompresser la liste lors du remplacement du séparateur par défautprint
d'un espace par une chaîne vide (sep=''
).Utilise l'
end
argument deprint
pour éventuellement ajouter des espaces, des arrêts complets et des sauts de ligne selon les besoins, en utilisant l'arithmétique modulaire. Un point final est utilisé après chaque neuvième mot ('.'*(i%9<1)
) et un saut de ligne après tous les quatre-vingt-un mots, sinon un espace l'est, obtenu par l'indexation dans une chaîne de deux caractères (' \n'[i%81<1]
).la source
Mathematica, 113 octets
Fonction non nommée qui produit une chaîne en sortie; cette chaîne est un essai martien où chaque phrase a trois mots et chaque paragraphe a trois phrases. (Sa sortie déterministe est ci-dessous.)
Le cœur de l’algorithme utilise le fait mathématique: les différences de la séquence Thue – Morse forment une séquence infinie des trois symboles –1, 0 et 1 qui n’a pas de répétition de chiffres contigus.
Differences@Array[ThueMorse,730]
génère cette séquence, de longueur 729.Puis
"ark"["bus","car"][[#]]&/@
est appliqué à cette séquence; ceci convertit chaque 1 en "bus" (le premier argument), chaque -1 en "voiture" (le dernier argument) et chaque 0 en "ark" (la fonction head).(p=Partition)[...,3]~p~3
divise cette séquence de mots en listes imbriquées composées chacune de trois listes de trois mots chacune. Enfin,StringRiffle[...,n=".\n",". "," "]
concatène tous les mots, avec des séparateurs différents selon les niveaux de la liste; et<>n
ajoute la période finale et la nouvelle ligne.La sortie ne semble pas exempte de répétition ....
Mathematica, 100 octets
Un portage direct de l'algorithme Jelly de Jonathan Allen.
la source
Print@"fng cdaz vpi. pascal broke basic. popplers taste great."
PHP, 86 octets
Génère un essai randomisé de 729 mots qui ne répète aucun mot.
Utilisez comme:
Explication:
la source
///, 95 octets
(nouvelle ligne supplémentaire à la fin, non visible ici)
Essayez-le en ligne!
Rédaction:
la source
JavaScript (ES6), 130 octets
Cet essai contient 774 mots martiens, issus d'un dictionnaire de 308 mots distincts, composés de toutes les lettres martiennes.
Les lettres sont sélectionnées de manière pseudo-aléatoire en utilisant la formule suivante:
Où
71
est le plus petit premier [1] pour lequel aucune répétition de mot contigu n'apparaît avec ce modulo.Afficher l'extrait de code
[1] Je n'ai testé que des nombres premiers au moment où j'ai écrit ce code. Le plus petit candidat non principal est
56
.la source
Python 3,
404270332339285266259 octetsCeci est une tentative pour créer un essai martien aléatoire en échantillonnant de manière aléatoire l'alphabet martien et en vérifiant quels mots fonctionnent.
Edit: -10 octets de la suggestion de Zachary T à utiliser
R=range
. -9 octets de changer.intersection(w)
à&set(w)
. -7 octets de changerA[random.randrange(21)]
àrandom.choice(A)
.Ungolfing
la source
import
)range(9)
à une variable, ainsi qu'au&
lieu de.intersection
?range
, puis en utilisant cela?