Crazy 8s Code Golf


34

Створіть програму, яка друкує всі цілі числа включно між інтервалом (a, b)та замінює кратні 8 у послідовності випадковими (рівномірно розподіленими, незалежними від інших символів), нечисловими, непробільними пробілами, друкованими символами ASCII.

Припустимо, що 0 <a <b у всіх випадках.

Якщо число має більше 1 цифри, переконайтеся, що кількість символів у заміні відповідає!

Приклади:

(1, 16) -> 1 2 3 4 5 6 7 $ 9 10 11 12 13 14 15 n@

(115, 123) -> 115, 116, 117, 118, 119, :F<, 121, 122, 123

(1, 3) -> 1 2 3

Неприклади:

(1, 16) -> 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16

(115, 123) -> 115 116 117 118 119 $ 121 122 123

Це кодовий гольф, тому найкоротший код у байтах виграє!

Поточний переможець:

Пайк (21 байт) каламутна

Найпопулярніше:

Пітон 2 (119 байт) Денніса


11
Вітаю, як зробити виклик, який поєднує в собі всі супер довгі речі, які можна реалізувати на моїй мові з гольфу
Blue

1
@muddyfish я маю на увазі це виклик;)
GracefulLemming

Я не впевнений, чи щось мені не вистачає, але чи повинні випадкові символи бути унікальними чи ні? Наприклад, якщо вхід був 16, 16, то чи може вихід бути aa ? Якщо це не так, що робити, якщо число має більше 85 цифр (якщо припустити, що я підрахував правильно)?
FryAmTheEggman

@FryAmTheEggman кожен символ повинен бути унікальним здебільшого, але якщо "a" і "a" вибрані випадковим чином послідовно, це нормально, але це не повинно відбуватися у всіх випадках, тому що ймовірність така низька
GracefulLemming

@FryAmTheEggman та випадок 16, 16 в інших прикладах або повертає 0 або 2 випадкових символи, але не турбуйтеся про цей випадок, оскільки завжди буде строго менше b
GracefulLemming

Відповіді:


4

Пайк, 22 21 байт

h1:Fi8%!I`lV~Kl7T>Hs0

Спробуйте тут!

Приймає вхідний сигнал у вигляді: higher,lower

h1:                   -  range(lower, higher+1, 1)
   F                  - for i in ^:
    i8%               -    i % 8 
       !              -   not ^
        I             -  if ^:
         `l           -    len(str(i))
           V          -   repeat V ^ times
            ~K        -        printable_ascii
              l7      -       ^.strip()
                T>    -      ^[10:]
                  H   -     random.choice(^)
                   s0 -    sum(^)

Списки - це все добре!
ВитонченийЛеммінг

Це цікаво, перший випадок, коли я бачив, де 8n, 8n викликає помилку
GracefulLemming

мій поганий, я неправильно прочитав результат
GracefulLemming

11

Python 2, 126 байт

Спробуйте в Інтернеті!

import random,string
def f(a,b):
 while b/a:print[a,eval('random.choice(string.printable[10:-6])+'*len(`a`)+"''")][a%8<1];a+=1

Велике спасибі Flp.Tkc та EasterlyIrk за всю їхню допомогу!


2
Ви можете використовувати b/aзамість цього a<=bі вам не потрібен ;кінець. Також import random,stringзберігається кілька байт. tio.run/nexus/…
Денніс

@ Денніс, дякую, що зняв 7 байт!
Хізер


6

zsh, 100 98 байт

for i in {$1..$2};{((i%8))&&<<<$i||<<<`yes 'shuf -e {!..~}|grep "[^0-9]"|head -c1'|head -$#i|zsh`}

Два вхідні аргументи передаються як аргументи командного рядка, а числа виводяться в окремі рядки.

for i in {$1..$2};{   # loop through the range
((i%8))&&             # if the number is not divisible by 8 (i % 8 != 0),
<<<$i||               # output it
<<<`                  # otherwise, output the following:
yes '                 # using `yes' as a golfy loop
shuf -e {\!..\~}      # shuffle the range of printable ASCII (minus space)
|grep "[^0-9]"        # get rid of numbers
|head -c1'            # take the first character
|head -$#i            # obtain a string with that code repeated len(i) times... 
|zsh                  # ... and eval it
`}

Чи можу я запитати, чому ви виводите числа, які діляться на 8?
ВитонченийЛеммінг

1
@Caleb Whoops, це був друкарський помилок. Малося на увазі читати " не ділиться на 8."
Дверна ручка

5

Математика, 96 байт

Range@##/.a_?(8∣#&):>Join[33~(c=CharacterRange)~47,58~c~127]~RandomChoice~⌊Log10@a+1⌋<>""&

Пояснення

Для входів mта n:

Range@##

Створювати {m, m + 1, m + 2, ... , n}

/.a_?(8∣#&):>

Для всіх чисел, які поділяються на 8 (дзвоніть, що a), застосуйте це правило заміни:

Join[33~(c=CharacterRange)~47,58~c~127]

Отримайте список усіх друкованих символів ASCII, крім цифр.

... ~RandomChoice~⌊Log10@a+1⌋

Псевдовипадково вибирають Floor[Log10[a] + 1]символи зі списку, дозволяючи дублікати.

<>""

Приєднуйтесь до персонажів.


ще один підхід для використання 96 байтівFromCharacterCode (r=Range)@##/.a_?(8∣#&):>FromCharacterCode[Join[33~r~47,58~r~127]~RandomChoice~⌊Log10@a+1⌋]<>""&
jaeyong заспівали

5

R, 73 байти

i=scan();x=i[1]:i[2];x[!x%%8]=sample(sapply(c(32:46,58:126),intToUtf8));x

Читає введення з stdin і замінює числа, що поділяються на, 8рівномірно обраним зразком символів ascii в діапазоні 32...47, 58...126. Щоб намалювати випадковий зразок, нам потрібен вектор символів, на жаль, intToUtf8()повертає один рядок, а не вектор, тому нам також доведеться векторизувати його за діапазоном, використовуючи sapply.


5

Python 2, 126 байт

(Денис не просто перевершує)

Бачачи, як я багато працював над відповіддю Вересу, я думав, що також розміщую свої власні рішення.

import random,string
def f(a,b):
 while b/a:print[a,eval('random.choice(string.printable[10:-6])+'*len(`a`)+"''")][a%8<1];a+=1

Це функція, яка бере два аргументи і друкується безпосередньо на STDOUT.

127 байт

import random,string
lambda a,b:[[x,eval('random.choice(string.printable[10:-6])+'*len(`x`)+`''`)][x%8<1]for x in range(a,b+1)]

Це неназвана анонімна функція - використовувати, призначити змінну (наприклад f), а потім зателефонувати за допомогою f(a, b). Це повертає вихід у вигляді списку.


Це неправильно. Вибрані випадковим чином символи можуть не містити цифр.
Денніс

@ Денніс добре, поверніться до моєї ідеї сплайсингу: P Дякую за голову вгору
FlipTack

Python 2, здається, популярний суперник, я люблю це!
ВитонченийЛеммінг

4

Піп , 28 байт

Fia,b+1Pi%8?i{RC@>PA@`\D`}Mi

Приймає числа як аргументи командного рядка та друкує список результатів, розділений новим рядком. Спробуйте в Інтернеті!

Пояснення:

                              a,b are cmdline args; PA is string of all printable ASCII
Fia,b+1                       For i in range(a, b+1):
       P                       Print this:
        i%8?i                  If i%8 is truthy (nonzero), i; otherwise:
             {           }Mi   Map this function to the digits of i:
                @>PA           All but the first character of PA (removes space)
                    @`\D`      Find all regex matches of \D (nondigits)
              RC               Random choice from that list of characters
                               The map operation returns a list, which is concatenated
                               before printing

4

JavaScript (ES6), 114 байт

f=(x,y)=>(x+"").replace(/./g,d=>x%8?d:String.fromCharCode((q=Math.random()*84)+(q>15?43:33)))+(x<y?[,f(x+1,y)]:"")

O.textContent = f(1,200)
<pre id=O>

Ці чортові вбудовані з 23-байтними іменами ....



@LarsW Якось пропустив це, дякую
ETHproductions

3

MATL , 26 байт

&:"@8\?@}6Y24Y2X-Xz@VnT&Zr

Спробуйте в Інтернеті!

Пояснення

&:        % Input a and b (implicit). Push range [a a+1 ... b]
"         % For each k in that range
  @       %   Push k
  8\      %   Modulo 8
  ?       %   If non-zero
    @     %     Push k
  }       %   Else
    6Y2   %     Push string of all printable ASCII chars
    4Y2   %     Push string '0123456789'
    X-    %     Set difference
    Xz    %     Remove space. Gives string of possible random chars
    @Vn   %     Push number of digits of k
    T&Zr  %     Random sample with replacement of that many chars from the string
          % End if, end for each, display (implicit)

Ого, круто! Гарна відповідь. +1
верес

@heather Дякую! У мене є відчуття, що це може бути скороченим ...
Луїс Мендо

3

Pyth , 24 байти

jm?%d8dsmO-r\~\ jkUT`d}F

Спробуйте в Інтернеті!

Пояснення:

jm?%d8dsmO-r\~\ jkUT`d}FQ  # Auto-fill variables
                      }FQ  # Splat inclusive range on the input
 m?%d8d                    # Map over each number, if it isn't divisible by 8 return it
       smO          `d     # for each other number, select a character at random for
                             each of it's digits and then flatten into one string
           r\~\            # Printable ASCII excluding space
          -     jkUT       # Setwise difference with numeric values (remove numbers)
j                          # Join with newlines

3

Bash + apg ,64, 76 байт

ЗМІНИ:

  • Виправлено випуск "8 8", виключіть числові символи з набору випадкових знаків, +12 байт

Гольф

seq $1 $2|sed "$[(7&(8-$1%8))+1]~8s/.*/a=&;apg -a1 -n1 -Mcsl -m\${#a} -x0/e"

Тест

>./crazy8 8 8
$

>./crazy8 115 123
115
116
117
118
119
As_
121
122
123

>./crazy8 1 16
1
2
3
4
5
6
7
"
9
10
11
12
13
14
15
x!

Не могли б ви пройти короткий прогулянку? Також мені цікаво побачити, що crazy8 8 8принесе врожай
GracefulLemming

@Caleb, на самому ділі це буде просто вихід як для 8 8, виглядає як я більш-golfed це небагато, працюючи над вирішенням цієї проблеми в даний час. Він також не фільтрує цифри з набору випадкових рядків символів (я теж пропустив це).
zeppelin

2

Perl 6 , 60 байт

{map {$_%8??$_!!S:g/./{grep(/\D/,"!".."~").pick}/},$^a..$^b}

Пояснення:

  • { map { }, $^a .. $^b }: Лямбда, яка бере два аргументи, формує список цілих чисел у цьому діапазоні та повертає її із наступним перетворенням, застосованим до кожного елемента:
  • $_ % 8 ?? $_ !!: Якщо елемент не ділиться на 8, передайте його без змін. Інакше ...
  • S:g/./{ }/: ... замініть кожен символ його рядкового подання значенням, що генерується цим виразом:
  • grep(/\D/, "!" .. "~").pick: Створіть діапазон символів між !та ~(у порядку Unicode), відфільтруйте цифри та випадково виберіть один із символів, що залишилися.

1

PHP, 163 байти

$n=range(48,57);$c=array_diff(range(32,126),$n);
foreach(range($a,$b) as $v){if($v%8!=0){echo $v;}
else{for($i=0;$i<strlen($v);$i++){echo chr($c[array_rand($c)]);}}}

Пояснення:

  • $n = range(48,57) Це коди ASCII для чисел, які знаходяться посередині спеціальних символів (32-47) та інших символів (58-126).
  • $c = array_diff(range(32,126), $n)Використовуючи $nмасив, виключіть числові символи та побудуйте масив прийнятних символів ASCII.
  • foreach(range($a,$b) as $v)Цикл за діапазоном значень від $aдо $b(включно), як $ v всередині циклу.
  • if($v % 8 != 0) { echo $v; }Перевірте, чи $ v рівномірно ділиться на 8 за допомогою оператора мод %.
  • else { for($i = 0; $i < strlen($v); $i++) { ... }} Якщо не рівномірно поділяється на 8, цикліть достатньо разів на кількість цифр у кількості та надрукуйте символи (на наступному кроці).
  • echo chr($c[array_rand($c)])Роздрукуйте один символ із прийнятного масиву значень ASCII в $c. array_randповертає індекс у масиві, тому ми маємо отримати фактичне значення для цього індексу, використовуючи $c[random_key].

Можливо, я міг би зробити це меншим, створивши $cінакше, і цикл для друку символів ASCII відчуває себе незграбним, тому я продовжуватиму роздумувати, як скоротити це.


1
Дякую Джейку! Радий почути від вас! Погляньте на мій новий виклик Random Pixel Poking, якщо у вас теж є час!
ВитонченийЛеммінг

1

postgresql9.6 251 символів

дуже довгий код, але і postgresql це робить.

do language plpgsql $$ begin for n in a..bloop raise info'%',case when 0=n%8then(select array_to_string(array(select*from(select chr(generate_series(33,126)))t where chr!~'\d'order by random()limit floor(log(n))+1),''))else n::text end;end loop;end;$$

відформатований sql тут:

do language plpgsql $$
begin
for n in a..b loop
    raise info '%',
    case when 0 = n % 8 then (
        select array_to_string(array(select * from (
            select chr(generate_series(33, 126))
        ) t where chr !~ '\d' order by random() limit floor(log(n)) + 1), '')
    ) else n::text
    end;
end loop;
end;
$$

1

Perl, 66 байт

map{$_%8||s%.%do{$_=chr rand 126}until/[!-\/:-~]/;$_%ge;say}<>..<>

Виконати з -Eпрапором:

perl -E 'map{$_%8||s%.%do{$_=chr rand 126}until/[!-\/:-~]/;$_%ge;say}<>..<>' <<< "8
16"

Це досить прямо:
- <>..<>створює список номерів між двома входами. А потім mapповторюється над ним:
- $_%8||...: the ...виконуються лише якщо $_кратне 8.
- s%.%xxx%ge: замініть кожен символ на xxx.
- do{$_=chr rand 126}until/[!-\/:-~]/вибираємо випадковий символ (від кодів 0 до 126), поки не отримаємо той, який задовольняє /[!-\/:-~]/, тобто. та, яка друкується і не є цифрою.
- say: роздрукувати його.


1

C (gcc) , 129 119 байт

s(a,r){a&&s(!isdigit(r=rand()%94+33)?putchar(r),a/10:a,0);}f(a,b){b>a&&f(a,b-1);b%8?printf("%d",b):s(b,0);printf(" ");}

Спробуйте в Інтернеті!

129 → 119 Використовуйте %94+33трюк від OOBalance

Безголівки:

s(a,r){
    a&&                                  // Loop recursively on a!=0
    s(!isdigit(r=rand()%94+33)           // Test random selection
      ?putchar(r),a/10                   // Print and reduce a
      :a                                 // Retry random selection
      ,0);                               // Second arg, recurse
}
f(a,b){
    b>a&&                                // Loop recursively on b>a
    f(a,b-1);                            // Reduce b, recurse
    b%8?printf("%d",b)                   // Print non 8's
       :s(b,0);                          // Call s() for 8's
    printf(" ");                         // Space separator
}

Ви можете зберегти 3 байти, якщо ви перейдете на роздільник нового рядка ( putsзамість printf).
OOBalance


1

C, 157 115 байт

f(a,b){b-a&&f(a,b-1);if(b%8)printf("%d",b);else for(;b;b/=10){while(isdigit(a=rand()%94+33));putchar(a);}puts("");}

Спробуйте його онлайн тут . Завдяки jxh за гольф на 42 байти.

Безгольова версія:

f(a, b) { // recursive function, parameters are implicitly int
    b-a && f(a, b-1); // recurse until a = b
    if(b % 8)            // if the number is a multiple of 8
        printf("%d", b); // simply print it
    else for(; b; b /= 10) { // while b > 0, lop off the last digit
        while(isdigit(a = rand() % 94 + 33)); // generate random characters in ASCII range [33, 127] until one is non-numeric
        putchar(a); // print the character
    }
    puts(""); // print a newline
}

Цю розмову можна продовжити у чаті .
DJMcMayhem

1

Java 10, 149 147 байт (лямбда-функція)

b->a->{var r="";for(;a<=b;r+=" ",a++)for(var c:(a+"").split("")){char t=0;for(;t<33|t>126|t>47&t<59;t*=Math.random())t=127;r+=a%8<1?t:c;}return r;}

Спробуйте в Інтернеті.

Java 10, 227 225 байт (повна програма)

interface M{static void main(String[]A){var r="";for(var a=new Long(A[0]);a<=new Long(A[1]);r+=" ",a++)for(var c:(a+"").split("")){char t=0;for(;t<33|t>126|t>47&t<59;t*=Math.random())t=127;r+=a%8<1?t:c;}System.out.print(r);}}

Спробуйте в Інтернеті.

Пояснення:

b->a->{          // Method with two integer parameters and String return-type
  var r="";      //  Result-String, starting empty
  for(;a<=b      //  Loop as long as `a` is smaller than or equal to `b`
      ;          //    After every iteration:
       r+=" ",   //     Append a space to the result-String
       a++)      //     And increase `a` by 1
    for(var c:(a+"").split("")){
                 //   Inner loop over the characters of the current number
      char t=0;  //    Random-char, starting at 0
      for(;t<33|t>126|t>47&t<59;
                 //    Loop until `t` is a non-digit printable ASCII char
          t*=Math.random())t=127;
                 //     Set `t` to a random character with a unicode in the range [0,127)
      r+=a%8<1?  //   If the current `a` is divisible by 8:
          t      //    Append the random character
         :       //   Else:
          c;}    //    Append the digit instead
  return r;}     //  Return the result

діапазон [0,127] не відповідає специфікаціям: "нечисловий,
непробільний простір для

@OOBalance Можливо, мій коментар не дуже добре пояснений, але саме тут t<33|(t>47&t<59)|t>126;це вище. В основному він генерує випадкове число в діапазоні [0,127), а потім перевіряє, чи воно дійсне (тому в діапазоні [33..47,59..126], всі друковані нецифрові символи ASCII). Якщо це: добре, додайте його. Якщо ні: знову генеруйте випадкове число в діапазоні [0,127)і ще раз підтверджуйте його, поки ми не знайдемо дійсний символ.
Кевін Круїссен

Ні, я вважаю, що ваш коментар прекрасний. Мій поганий :)
OOBalance

1

APL (Dyalog Extended) , 32 байти

{(?84¨⍕⍵)⊇⎕D~⍨'!''~'}¨@{0=8|⍵}…

Спробуйте в Інтернеті!

Величезне спасибі Адаму та дзаїмі за допомогу. Перше використання Dyalog Extended!

Пояснення:

{(?84¨⍕⍵)⊇⎕D~⍨'!''~'}¨@{0=8|⍵}…   Dyadic 2-train

                                  Tacit range: list of numbers from left arg 
                                   to right arg inclusive
{(?84¨⍕⍵)⊇⎕D~⍨'!''~'}¨@{0=8|⍵}    Monadic function applied to above          
                        {     }    Function definition
                           8|⍵     8 modulo every item in our range
                         0=        Transform list into a boolean vector, with
                                   1 where item was equal to zero, 0 otherwise
                      ¨@           Applies left function to each item selected
                                   by above
{                    }             Function definition
              '!''~'              Range of all printable ASCII chars
          D~⍨                     Remove numeric characters from above
 (    ⍕⍵)                          Convert function argument to string
                                   (e.g., 123 -> "123")
   84¨                             For each character, replace with number 84
                                   (number of non-numeric printable ASCII chars)
  ?                                Generate random number from 1-84 for each
                                   84 in list
                                  Index the ASCII char list with above random
                                   numbers

1

Scala , 198 байт

Вдосконалена функціональна версія з незмінним станом (04.04.2018)

  def S(a: Int, b: Int)={
    val c=(33 to 47)++(58 to 126)
    val r = (a to b).toStream.map {case x if x%8==0=>c(Random.nextInt(c.length)).toChar.toString
      case x => String.valueOf(x)}
    r}

Спробуйте в Інтернеті!

Рішення функціонального стилю в Scala (350 байт) для задоволення.

def r(a:Int, b:Int)={
    var l=(33 to 47).toList:::(58 to 126).toList
    l=Random.shuffle(l)
    var x=ListBuffer[String]()
    var k=0
    (a to b).toList.foreach{e=>{
         if(k==l.length){k=0
         l=Random.shuffle(l)}
         if (e.toInt%8==0){x+=l(k).toChar.toString
           k+=1}
         else{x+=e.toString
             k+=1}}}
    x}

Пропозиції щодо вдосконалення вітаються.


1
Тут на коді гольфу ми дозволяємо лише відповіді, які, принаймні, намагалися грати в гольф. Це означає 1 імен змінних імен та видалення пробілів андроїд, додавши до вашої відповіді кількість байтів
Blue

@muddyfish ОК, я гольфував свій код, як андроїд додає кількість байтів?
firephil

Мені зараз здається чудовим
Синій

0

Пітон 2, 180 байт

from random import*
def f(a,b):
 for i in range(a,b+1):
  if i%8<1:
   k,i=str(i),''
   for _ in k:i+=choice([chr(j)for j in range(33,48)]+[chr(j)for j in range(57,126)])
  print i

Редагувати:

Дякую @ Flp.Tkc за те, що зрозумів, що я не прочитав завдання належним чином.

Спасибі @Caleb за вказівку, що я міг би скористатися кількома, щоб зменшити кількість байтів.

Дякуємо @Dennis за вказівку на те, що цифри не можуть бути включені.

EDIT 2:

Поточну версію, ймовірно, можна спростити більше, ніж є.


0

PowerShell , 82 89 байт

$a,$b=$args;$a..$b|%{($_,(-join[char[]](33..47+58..127|random -c "$_".Length)))[!($_%8)]}

Спробуйте в Інтернеті!


1
58..127 не включає символи для друку ASCII в нижньому діапазоні від 33 (!) До 47 (/).
zeppelin

@zeppelin правда, я не вважав, що це є вимогою, але перечитавши її, я вважаю, що це повинно бути, якщо це буде рівномірний розподіл. Оновлено!
британіст

0

QBIC , 79 байт

::[a,b|~c%8=0|[_l!c$||_R33,116|~e>47 and e<58|e=e+z]Z=Z+chr$(e)]\Z=Z+!c$]Z=Z+@ 

Пропуск чисел - дорога справа, ось версія, яка також може випадково вибрати 0-9на 20 байт менше:

::[a,b|~c%8=0|[len(!c$)|Z=Z+chr$(_r33,126|)]\Z=Z+!c$]Z=Z+@ 

Вибірка зразка для 1, 89

1 2 3 4 5 6 7 U 9 10 11 12 13 14 15 M9 17 18 19 20 21 22 23 ^L 25 26 27 28 29 30 
31 <U 33 34 35 36 37 38 39 gH 41 42 43 44 45 46 47 aJ 49 50 51 52 53 54 55 1b 57 58 59 60 
61 62 63 ,C 65 66 67 68 69 70 71 ]; 73 74 75 76 77 78 79 [B 81 82 83 84 85 86 87 Ix 89 

Пояснення:

::        Get inputs 'a' and 'b' from the command line
[a,b|     FOR(c=a; c<=b; c++)
~c%8=0|   IF c is cleanly divisible by 8 THEN
 _l!c$|   Take the length (_l) of the string representation (! ... $) of c 
[      |  FOR (d = 1; d<= length(c); d++)
_R33,116| Set e to a random value in the range 33 - 116 (all the printable ascii's - 10)
~e>47     IF e falls between 47
and e<58| and 58 (ASCII code for 0-9) THEN 
e=e+z     e = e + 10 (z == 10 in QBIC)
]         END IF
Z=Z+      Add to Z$
chr$(e)]  ASCII character e
\         ELSE if c is not cleanly divisible by 8
Z=Z+!c$   Add to Z the string representation of c
]         NEXT
Z=Z+@     Add a space to Z$ (@ is an implicitly delimited string literal with 1 significant space)

( Z$ is implicitly printed at end of program )

0

05AB1E , 17 байт

ŸεD8ÖižQžhK¦.rsg£

Приймає введення як highest\nlowestі видає список.

Спробуйте в Інтернеті або перевірте всі тестові справи .

Пояснення:

Ÿ                  # Create a list in the range [low (implicit) input, high (implicit) input]
 ε                 # Map each value to:
  D                #  Duplicate the value
   8Öi             #  If it's divisible by 8:
      žQ           #   Push all printable ASCII characters (" " through "~")
        žhK        #   Remove all digits
           ¦       #   Remove the first character (the space)
            .r     #   Randomly shuffle the remaining characters
              s    #   Swap to take the map value again
               g   #   Get its length
                £  #   And leave that many characters from the string
                   # (and implicitly output the resulting list after we're done mapping)

0

Japt , 20 байт

;òV ®%8?Z:EÅk9ò)öZìl

Спробуй це

;òV ®%8?Z:EÅk9ò)öZìl     :Implicit input of integers U & V
 òV                      :Range [U,V]
    ®                    :Map each Z
     %8                  :  Modulo 8
       ?Z:               :  If truthy, return Z, else
;         E              :  Printable ASCII
           Å             :  Slice off first character
            k            :  Remove
             9ò          :    Range [0,9]
               )         :  End remove
                 Zì      :  Digit array of Z
                   l     :  Length
               ö         :  Get that many random characters from the string

0

Четвертий (gforth) , 128 байт

include random.fs
: f 1+ swap do i 8 mod if i . else i 0 <# #s #> 0 do 83 random 33 + dup 47 > 10 * - emit loop ."  "then loop ;

Спробуйте в Інтернеті!

Пояснення

Цикл від початку до кінця, друкуйте число, якщо не кратне 8, інакше отримайте кількість цифр у номері та надрукуйте стільки випадкових символів, а потім пробіл

Пояснення коду

include random.fs          \ include/import the random module
: f                        \ start new word definition
  1+ swap                  \ add 1 to end number, because forth loops are [start, end), and swap order
  do                       \ start counted loop form start to end
    i 8 mod                \ get the remainder of dividing i (loop index) by 8
    if                     \ if true (not 0, therefore not multiple of 8)
      i .                  \ print the index
    else                   \ otherwise
      i 0                  \ convert index to double-length number
      <# #s #>             \ use formatted numeric output to convert number to a string
      0 do                 \ loop from 0 to (string-length - 1)
        84 random          \ get random number between 0 and 83
        33 +               \ add 33
        dup 47 >           \ check if result is larger than 47
        10 * -             \ if it is add 10 to result (results in number in range: 33-47,58-126)
        emit               \ output ascii char corresponding with number
      loop                 \ end inner loop
    ."  "then            \ output a space and then close the if/else
  loop                   \ end the outer loop
;                        \ end the word definition

UnGolfed

Зазвичай я не знімаю своїх рішень, але це досить довгий / складний, що я думаю, що це потрібно

include random.fs

\ get the length (in digits) of a number
: num-length 0 <# #s #> nip ;

\ check if a number is a multiple of another
: is-multiple mod 0= ;               

\ get a random printable non-digit ascii char           
: random-char 84 random 33 + dup 47 > 10 * - ;  

\ get a "random" string of printable ascii chars the same length as a number
: rand-str num-length 0 do random-char emit loop space ;

\ print numbers from a to b, replacing multiple of 8 with a random ascii string of the same length
: crazy-eights 1+ swap do i 8 is-multiple if i rand-str else i . then loop ;

0

PHP , 130 байт

function($a,$b){for(;$a<=$b;$a++)echo$a%8?$a:(function($l){while($l--)echo chr(($x=rand(44,128))-($x>58?:11));})(strlen($a))," ";}

Спробуйте в Інтернеті!

Безголівки:

function c8( $a, $b ) { 
    for( ; $a<=$b; $a++ ) {                // loop between a -> b
        echo $a % 8 ? $a :                 // every 8, call anon func instead of value
            (function($l) {
                while( $l-- ) {            // repeat length of value
                    $x = rand( 44, 128 );  // range size is printable chars [33,47][58,127]
                    $x-= $x > 58 ?: 11;    // Subtract one from x. If x was less than or 
                                           // equal to 58, subtract a further ten from it
                                           // so that it now falls within the 33-47 range
                    echo chr( $x );        // echo ASCII value
                }
            })( strlen( $a ) )," ";
    }
}

Так, моя помилка. Щодо $x-= $x > 58 ?: 11; // subtract 11, if x is less than 58- ви могли б детальніше розробити?
Джонатан Фрех

@JonathanFrech, іншими словами, ми хочемо, щоб число було від 33-47 до 58-127. Отже, ми вибираємо число, яке становить 58 мінус розмір нижнього діапазону. Якщо число нижче 58, воно просто переводиться в нижній діапазон, віднімаючи різницю. Тому що, звичайно, ми не можемо відображати цифри (ASCII char 48-57)
640 КБ

Тернар - це лише ярлик для цього. В основному $ x> 58 оцінює до 1, і тому ми або віднімаємо це, або 11 від $ x. У випадку, коли вона вища, вона компенсується значеннями ASCII в операторі rand () на один вищий. Ви можете бачити, що це генерує рівномірно випадковий (настільки ж рівномірний, наскільки здатний rand PHP ()): tio.run/…
640KB

Я думаю, що я приблизно знаю, що робить оператор Елвіса, я просто думаю, що ваш коментар вводить в оману.
Джонатан Фрех

Я б подумав, що це працює так Subtract one from x. If x was less than or equal to 58, subtract a further ten from it., ні?
Джонатан Фрех

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.