Hiccup une chaîne


16

Votre défi consiste à écrire un programme ou une fonction qui hoquette une chaîne. Il doit prendre une chaîne en entrée (via toute méthode standard), puis procédez comme suit:

  1. Générez un entier aléatoire (pas nécessairement uniforme) n compris entre 1 et 10 inclus.
  2. Attendez n secondes.
  3. Imprime les n caractères initiaux / suivants de l'entrée, ou le reste de l'entrée s'il y a moins de n caractères.
  4. S'il reste une entrée à imprimer, revenez à l'étape 1.

Règles

  • L'entrée sera toujours une chaîne non vide contenant uniquement des caractères ASCII (32-126).
  • Le temps d'attente ne doit pas être exactement n secondes, mais il doit être à moins de 10% de n .
  • Vous pouvez imprimer un retour à la ligne à chaque fois qu'une section de texte est imprimée.

Exemple

Un espace ici représente 1 seconde. Si l'entrée est Hiccupinator!, une sortie peut être:

   Hic     cupin a          tor!

Notation

Il s'agit de , donc le code le plus court en octets l'emporte .


Les commentaires ne sont pas pour une discussion approfondie; cette conversation a été déplacée vers le chat .
Dennis

Peut-on utiliser des espaces pour des langages qui ne supportent pas l'attente / n'ont pas une notion de temps?
FliiFe

Je parie que n'importe quelle langue a un moyen de passer du temps sans produire de sortie, @FliiFe!
Omar

Réponses:


9

Scratch, 16 blocs + 6 octets

Code

Suppose que l'entrée est déjà définie comme une liste de caractères ( ["H","e","l","l","o"," ","W","o","r","l","d"])


Peut-on jouer au golf de quelque façon que ce soit?
OldBunny2800

Ce n'est pas une méthode de notation valide. Voir meta post .
mbomb007

Seriez-vous prêt à le corriger sur la base du consensus communautaire?
OldBunny2800

1
Je n'ai pas Scratch. C'est votre responsabilité, puisque vous avez posté la réponse. ScratchBlocks2 est même livré avec un générateur pour créer du code texte à partir d'un projet.
mbomb007

5

Pushy , 20 17 16 ou 13 octets

Selon ce qui est autorisé, il existe deux solutions.

16 octets:

@$LT1U&Wm:v;O"cI

Donner des arguments sur la ligne de commande: $ pushy hiccup.pshy 'hiccupinator'. Cela imprime avec des retours à la ligne après chaque «hoquet». Voici la ventilation:

                      % Implicit: input on stack as charcodes
@                     % Reverse input, so chars are pulled from start
 $             I      % While there are items on stack:
   T1U                %   Push a random number, 1-10
      &W              %   Wait that many seconds
  L     m:            %   min(time waited, chars left) times do:
          v;          %     Pull a char from the input.
            O"c       %   Print & delete pulled chars

13 octets:

En codant la réponse ci-dessus, j'ai trouvé cette solution beaucoup plus courte:

N@$L1TU&Wm:'.

Bien qu'il fasse une chose similaire, il imprime directement la chaîne plutôt que de construire une nouvelle chaîne, pour moins d'octets. Cela nécessite laN début du programme pour éviter les sauts de ligne, sinon chaque caractère se trouverait sur un saut de ligne.

Cependant, en testant cela, j'ai remarqué un bug - stdout est mis en mémoire tampon, donc le programme attendrait toute la longueur, puis afficherait la chaîne hoquetée.

J'ai corrigé cela dans le dernier commit en ajoutant un simple.flush() - ce n'est techniquement pas en ajoutant une nouvelle fonctionnalité à la langue, juste en corrigeant un bug, mais je comprends si vous ne tenez pas compte de cette réponse :)

La ventilation ressemble à ceci:

        % Implicit: input on stack as charcodes
N       % Set trailing newlines to False
@       % Reverse stack (so the charcodes are pulled off in order)
$       % While there are items left to print:
L       %    Push stack length
1TU     %    Push a random number 1-10
&W      %    Wait that amount of time
m:      %    min(time waited, chars left) times do:
'.      %      Pop and print last char

La convention chez PPCG est que les langues sont définies par l'implémentation (bugs et tous). Puisque le commit postdate le défi, cette partie n'est pas en compétition
Luis Mendo

@LuisMendo ok, merci pour la clarification :)
FlipTack

Belle réponse BTW :-)
Luis Mendo

4

Javascript (ES6) 91 89 octets

f=s=>s&&setTimeout(_=>console.log(s.slice(0,n))|f(s.slice(n)),(n=1+Math.random()*10)<<10)

console.log(2 + f.toString().length); 
f('Hello sweet world!')                                       

économisé 2 octets grâce à @zeppelin

Abuse la tolérance de 10% pour le temps d'attente en attendant des n<<10 === 1024*nmillisecondes.

Puisque vous avez dit que le temps d'attente devait se situer à moins de 10% de n , j'ai décidé d'enregistrer un octet et d'attendre 999 millisecondes plutôt que 1 seconde.

Je n'ai plus besoin de la bêtise de 999 millisecondes grâce à @ETHProductions


1
Hmm, je ne sais pas si la nouvelle date ()% 10 compte pour "aléatoire" par n'importe quelle mesure.
zeppelin

@zeppelin Fair point, selon la définition standard ça ne compte pas. ( meta.codegolf.stackexchange.com/a/1325/56071 ). Je vais le changer en conséquence.
Lmis

Vous pouvez également enregistrer une paire d'octets, en supprimant "| 0"
zeppelin

2
Vous savez, vous pouvez aussi exprimer 1000 en trois octets: 1e3;-)
ETHproductions

1
> (1 + 0,099999 * 10) * 999> 1997 Vrai, mais vous pouvez probablement remplacer * 999 par << 10, pour contourner ce problème: (1 + 0,099999 * 10) << 10 => 1024, (1 + 0,99999999 * 10) << 10 => 10240
zeppelin

4

Python 2, 93 92 octets

import random,time
def F(s):
 if s:n=random.randint(1,10);time.sleep(n);print s[:n];F(s[n:])

-1 octet grâce à Flp.Tkc

Je suis sûr qu'il existe un moyen de raccourcir random.randint et time.sleep, mais from random,time import*ne fonctionne pas ...


1
from random,time import*ne fonctionne pas car Python ne sait pas à partir de quel module vous souhaitez importer des bibliothèques.
Erik the Outgolfer

Python 3 est un octet de plus. Insérez un '(' entre l'impression et 'i' et un ')' avant le support
George

1
Adaptation de ceci à minipy (Python 3): while v1:n=ri(1,10);_i("time").sleep(n);p(v1[:n]);v1=v1[n:];(Prend la saisie des
arguments de

Vous pouvez écrire ce 1 octet plus court en fonction récursive: import random,time, puis def F(s):retour à la ligneif s:n=random.randint(1,10);time.sleep(n);print s[:n];F(s[n:])
FlipTack

3

Perl 6 , 62 octets

{$_=$^a;while $_ {sleep my \t=(1..10).roll;put s/.**{0..t}//}}

Étendu

{ # block lambda with parameter 「$a」

  $_ = $^a; # declare parameter, and store it in 「$_」
            # ( the input is read-only by default )

  while $_ {
    # generate random number and sleep for that many seconds
    sleep my \t=(1..10).roll;

    put
      s/              # substitution on 「$_」 ( returns matched text )
        . ** { 0..t } # match at most 「t」 characters
      //              # replace it with nothing
  }
}

1

Lot, 131 octets

@set/ps=
:l
@set/an=%random%%%10+1
@timeout/t>nul %n%
@call echo(%%s:~0,%n%%%
@call set s=%%s:~%n%%%
@if not "%s%"==2" goto l

L'utilisation set/pn=<nulaurait donné un effet plus agréable, sauf qu'elle réduit les espaces.


1

Pyth, 16 octets

Wz.d_JhOT<zJ=>zJ

Vous pouvez l' essayer en ligne , mais cela ne fonctionne pas bien car l'interpréteur en ligne n'affiche la sortie qu'une fois le programme terminé.

Explication

Wz         While z (the input) is not empty:
     hOT   Get a random number between 1-10 (inclusive)
    J      Set the variable J to that number
 .d_       Sleep for that number of seconds
 <zJ       Get and implicitly print the first J characters of the input
  >zJ      Get all characters of z at and after index J
 =         Set z to that string

1

MATL , 19 octets

`10YrtY.ynhX<:&)wDt

Comment ça fonctionne

Essayez-le en ligne! Le compilateur en ligne produit progressivement les sorties avec les pauses.

`         % Do...while loop
  10Yr    %   Random integer from 1 to 10
  tY.     %   Duplicate. Pause that many seconds
  y       %   Duplicate the second-top element. This is the remaining string; or it
          %   takes the input implicitly in the first iteration
  n       %   Number of elements
  hX<     %   Minimum of the number of elements and the random number
  :       %   Range from 1 to that
  &)      %   Apply as index. Push the substring as given by the index and the
          %   remaining substring
  w       %   Swap
  D       %   Display
  t       %   Duplicate the remaining substring. This is used as loop condition:
          %   if non-empty execute next iteration
          % End loop implicitly

1

BaCon , 93 octets

Une solution en BASIC. La fonction RANDOM () génère un nombre compris entre 0 et n-1, nous devons donc utiliser RANDOM (11) pour obtenir un nombre compris entre 0 et 10 inclus.

INPUT s$
WHILE LEN(s$)>0
n=RANDOM(11)
SLEEP n*1000
?LEFT$(s$,n),SPC$(n);
s$=MID$(s$,n+1)
WEND

Exemple de session, la première ligne est l'entrée, la seconde la sortie:

Hiccupinator!
Hiccupi       nato    r!

2
Si ce que vous dites est vrai, votre fonction aléatoire devrait être n=RANDOM(10)+1, votre ligne de code générera un nombre compris entre 0 et 10 inclus, pas entre 1
Octopus

1
@Octopus Cela n'a pas d'importance, car il dormira sans temps et ne produira aucune sortie dans ce cas.
Neil

Correction de la faute de frappe dans mon explication.
Peter

1

Perl, 42 octets

Code de 41 octets + 1 pour -n.

$|=$-=--$-||sleep 1+rand 10,print for/./g

J'ai dû forcer Perl à vider la sortie car il ne montrait rien jusqu'à la fin au début, d'où le réglage $|. Nous utilisons $-pour suivre le nombre de caractèresprint car cela ne peut pas être négatif (donc je peux utiliser --$-et ce sera faux quand il sera vide) et c'est aussi floors, bien que puisque j'utilise le retour desleep pour cela maintenant, cela ne fonctionne pas n'a pas vraiment d'importance.

Usage

perl -ne '$|=$-=--$-||sleep 1+rand 10,print for/./g' <<< 'Hello, World!'
    Hell      o, Wor     ld!
# spaces showing delay!

0

Rubis, 56 octets

f=->s{n=sleep rand 1..10;print s.slice!0,n;f[s]if s!=""}

Une lambda récursive. Appelez comme f["Hello, World!"].


0

> <> (Poisson) 103 88 octets

5>:?vl1-?!v+40.    >~
   1x2v   
>^  0  |:!/>:?!v1-b2.
^-1}< <     |~!/:?!^1-i:1+?!;of3.

Interprète en ligne trouvé ici!

Première tentative à ce problème (pas joué au golf).

Il attend un certain nombre de boucles (n) car le poisson n'a pas de temporisateur accessible (Exécution en ticks).

Édition 1: Déplacement de la dernière ligne vers le haut (2 derniers caractères et réutilisation des valeurs de départ. (Économie de 15 octets).


0

Bash, 78 octets

Comme personne n'a encore publié de solution Bash, en voici une. Simple, mais assez petit.

Golfé

H() { N=$(($RANDOM%10+1));sleep $N;echo ${1:0:$N};S=${1:$N};[ "$S" ] && H $S;}

Tester

>H "It's the Hiccupinator"
It's the
Hiccupi
n
ator

0

PHP, 81 octets

for(;''<$s=&$argv[1];$s=$f($s,$n))echo($f=substr)($s,0,sleep($n=rand(1,10))?:$n);

utiliser comme:

php -r "for(;''<$s=&$argv[1];$s=$f($s,$n))echo($f=substr)($s,0,sleep($n=rand(1,10))?:$n);" "Hiccupinator!"

0

C ++ 14, 202 octets

#import<thread>
void f(auto c){if(c.size()<1)return;int n=(uintptr_t(&c)%99)/10+1;std::this_thread::sleep_for(std::chrono::seconds(n));std::cout<<c.substr(0,n)<<std::endl;f(n<c.size()?c.substr(n):"");}

Nécessite une entrée pour être std::string

Non golfé et utilisation:

#include<iostream>
#include<string>

#import <thread>

void f(auto c){
  if (c.size() < 1) return;
  int n=(uintptr_t(&c) % 99) / 10 + 1;
  std::this_thread::sleep_for(std::chrono::seconds(n));
  std::cout << c.substr(0,n) << std::endl;
  f(n < c.size() ? c.substr(n) : "");
}

int main(){
  std::string s="abcdefghijklmnopqrstuvwxyz";
  f(s);
}

using namespace std;devrait sauver 5 octets de tous ces std::s
Alfie Goodacre

@AlfieGoodacre le 5 std::est seulement dans le code d'utilisation, dans le golf il n'y en a que 4
Karl Napf

Ah donc c'est identique!
Alfie Goodacre

0

C #, 205 octets

void X(string s){Random r=new Random();int n=r.Next(1,11);while(n<s.Length){Console.WriteLine(s.Substring(0,n));s.Remove(0,n);n*=1000;System.Threading.Thread.Sleep(n);n=r.Next(1,11);}Console.WriteLine(s);}

Je suis sûr que cela peut être détruit, je ne l'ai pas vraiment optimisé du tout tel qu'il est.

Non-golfé:

void X(string s)
{
    Random r = new Random();
    int n = r.Next(1,11);
    while(n < s.Length)
    {
        Console.WriteLine(s.Substring(0,n));
        s.Remove(0,n);
        n *= 1000;
        System.Threading.Thread.Sleep(n);
        n = r.Next(1,11);
    }
    Console.WriteLine(s);
}

0

PHP, 74 octets

for($s=$argv[1];$s[$p+=$n]>"";print substr($s,$p,$n))sleep($n=rand(1,10));

Courez avec php -r 'code' "string".


0

C, 149 octets, non testé

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
int f(char *s){int n;while(*s){sleep(n=rand()%10+1);for(;*s&&n--;s++)printf("%.*s",1,s);}}

pour exécuter, ajouter

int main(){f("Programming Puzzles & CodeGolf");}

puis compilez et exécutez


0

Python 3, 99 caractères

i=input()
import os,time
while len(i):n=1+ord(os.urandom(1))%10;time.sleep(n);print(i[:n]);i=i[n:]
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.