Десять десятків елементів, яких ти не повіриш, є в цьому масиві


10

AKA: Створюйте Clickbait з масиву.

Враховуючи масив цілих чисел, генеруйте деякий гідний вигляд кліків на основі його розташування та довжини:

  • Якщо це 20 елементів або менше, ви можете скласти список Top X. Параметри: довжина масиву.
  • Прем'єр-номери - це знаменитості, тому в будь-який час двоє з них знаходяться поруч один з одним, це буде передаватися як плітки. Параметри: два суміжні прайми в тому порядку, в якому вони відображаються в масиві.
  • Якщо будь-яке число з’являється в масиві двічі або більше, то це шокує і неймовірно, і кожен повинен про це почути. Якщо кілька номерів з’являються двічі, складіть сюжет новин для кожного. Роздрукуйте це один раз на унікальний номер. Параметри: поява числа, виміряне загальним виглядом.
  • Якщо ви бачите 3+ елементів у сортованому монотонно зростаючому порядку з подальшим раптовим зменшенням, тоді розкажіть про те, як вони сортуються та дражнять, що буде далі. Робіть це лише один раз на пряму. Параметри: довжина прямої.

Це відповідні кліки, які ви повинні використовувати:

The Top {{N}} Array Elements
{{N1}} And {{N2}} Were Spotted Together, You Won't Believe What They Did
These {{N}} Elements Will Blow Your Mind
{{N}} Elements Sort Themselves, Find Out What Comes Next

Пам'ятайте, що ви представляєте дешеву медіа-компанію, тому вам потрібно буде доїти це та надрукувати всі можливі заголовки. Якщо є 2 однакових заголовки, надрукуйте їх обох.

Наприклад, якщо вам надано цей масив ...

1,2,3,4,2,1,1,5,6

Ви повинні вивести все це у довільному порядку:

The Top 9 Array Elements
2 And 3 Were Spotted Together, You Won't Believe What They Did
These 2 Elements Will Blow Your Mind
These 3 Elements Will Blow Your Mind
4 Elements Sort Themselves, Find Out What Comes Next

Зверніть увагу на відсутність цього заголовку:

3 Elements Sort Themselves, Find Out What Comes Next

Як кодовий гольф, виграє найкоротша відповідь у байтах.


1
@Arnauld там немає різкого зниження, тому просто надрукуйте перші 3 заголовки.
Нісса

1
Зазвичай я не заперечую, але -1, щоб створити виклик лише для того, щоб використовувати заголовок клацання приманки та абсолютно непотрібний вихідний формат для виклику типу "do A, B і C, oh, а також D". Ви дійсно повинні читати речі, яких слід уникати, коли пишете завдання .
ბიმო

8
@BMO Можливо, вам слід частіше читати пісочницю. Це було там тривалий час, коли ви, можливо, висловили свою думку. Крім того, багато проблем на цьому веб-сайті використовують клікбайт, це не так, що це єдиний виклик, щоб зробити це lol
Conor O'Brien

6
Є достатньо кращих випадків, які я пропоную вам написати опорну реалізацію, яка демонструє точні логічні відповіді.
Лінн

5
@ ConorO'Brien: Напевно, я мав би, якби бачив його там, я озвучив свою думку там. Але я подумав, що можу дати свою причину, тому що мовчки заборонити нікому користь. Щодо принади для кліку, я думаю, що існує велика різниця між привабливим заголовком для гарного виклику і завданням, яке було зроблено лише для використання заголовка кліку.
ბიმო

Відповіді:


5

Желе , 142 байти

I>-ṣ0ṖS€ỊÐḟ‘ɓĠL€ḟ1,ɓ¹ƝÆPẠ$ÐfW;ɓLẋ<¥21W;ż@€"“æƥu®ụ³Km&|°ẓz“ṿ$¥{d3ɓFȤSJẎVḍnṃ*¹0Ḟ¬ȤɲƝċƲạB'ɼɓ.€⁺Ƒ“¢ßUṡʠx\~⁻ḅėʠAƓḳ¶e<“½ė!Ƙ¥Ḍ3]⁷ṀƭȮþċ⁽?ṫĠƁÆȦØ⁾Ż»ṣ€⁷¤

Монадичне посилання, що приймає список цілих чисел, повертає список списків кліків (кожен з яких - це список символів і цілих чисел). Для повноцінного програмного друку розділених рядків кліків на стрічковому каналі просто додайте ẎYдо кінця.

Спробуйте в Інтернеті! (Footer складає єдиний список кліків, а потім відокремлює їх новими рядками.)
... або дивіться приклад, наведений у питанні.

Як?

99 найправіших байтів цього Посилання утворюють nilad (функція з нульовими аргументами, тобто константа):

“...“...“...“...»ṣ€⁷¤
                    ¤ - nilad followed by link(s) as a nilad:
“...“...“...“...»     - list of compressed strings (the four clickbait-texts with the
                      -   integers replaced with line-feed characters)
                   ⁷  - literal line-feed character
                 ṣ€   - split-at for €ach (read to interweave with the integers)

Позначимо ці текстові частини такими X, як тепер Посилання:

I>-ṣ0ṖS€ỊÐḟ‘ɓĠL€ḟ1,ɓ¹ƝÆPẠ$ÐfW;ɓLẋ<¥21W;ż@€"X - Link: list of integers Z
                                             - # get the monotonically increasing runs:
I                                            - incremental differences of Z
 >-                                          - greater than -1 (vectorises)
   ṣ0                                        - split at zeros
     Ṗ                                       - pop (discard final run)
      S€                                     - sum each (length - 1 for all runs)
         Ðḟ                                  - filter discard if:
        Ị                                    -   insignificant (discard any 0s or 1s)
           ‘                                 - increment (yielding all run-lengths >= 3)
            ɓ                                - new dyadic chain with that on the right
                                             - # get the multiplicities:
             Ġ                               - group indices of Z by value
              L€                             - length of €ach
                ḟ1                           - filter discard 1s
                  ,                          - pair with right (the run-lengths)
                   ɓ                         - new dyadic chain with that on the right
                                             - # get the prime-pairs
                     Ɲ                       - for each pair in Z
                    ¹                        -   identity (do nothing)
                          Ðf                 - filter keep if:
                         $                   -   last two links as a monad:
                      ÆP                     -     is prime? (vectorises)
                        Ạ                    -     all?
                            W                - wrap in a list
                             ;               - concatenate with right ([multiplicities,runs])
                              ɓ              - new dyadic chain with that on the right
                                             - # get top count as a list
                               L             - length
                                   21        - literal 21
                                  ¥          - last two links as a dyad
                                 <           -   less than? (1 if 20 or less, else 0)
                                ẋ            -   repeat ([length] if 20 or less, else [])
                                     W       - wrap in a list (i.e. [[length]] or [[]])
                                      ;      - concatenate with right ([[prime pairs],[multiplicities],[run-lengths]])
                                             - ...now we have [[length],[prime pairs],[multiplicities],[run-lengths]]
                                          "X - zip with X (the text-parts)
                                         €   -   for each (item in the current list):
                                       ż@    -     interleave with swapped arguments

Вражає! : P Навіть не використовував речення ... вау
NL628

2
Це тому, що Jelly має можливість мати стиснуті струни. Речення є в “...“...“...“...»частині коду, а рядки замість цифр - як це
Джонатан Аллан

1
Це ціла лота Желе ...
Khuldraeseth na'Barya

Найдовший желе-гольф, який я бачив. Моя відповідь тут близька, але все ж коротша на 16 байт
dylnan

@dylnan я бить_наст кілька гольф желе , які більше, пара з яких я думаю , це більш вражаюче
Jonathan Allan

2

Java 10, 467 457 456 453 байт

a->{int l=a.length,i=0,p=0,P=0,m[]=new int[999],t;String e=" Elements ",r=l<21?"The Top "+l+" Array"+e+"\n":"";for(;i<l;r+=i>0&&p(p)>1&p(t=a[i-1])>1?p+" And "+t+" Were Spotted Together, You Won't Believe What They Did\n":"",m[a[i++]]++)if(p<(p=a[i]))P++;else{r+=P>2?P+e+"Sort Themselves, Find Out What Comes Next\n":"";P=1;}for(;l-->0;r+=m[l]>1?"These "+m[l]+e+"Will Blow Your Mind\n":"");return r;}int p(int n){for(int i=2;i<n;n=n%i++<1?0:n);return n;}

Припускає, що масив введення буде містити значення 0 < N < 1000( [1,999]).

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

a->{                     // Method with integer-array parameter and String return-type
  int l=a.length,        //  Length of the input-array
      i=0,               //  Index-integer
      p=0,               //  Previous item, starting at 0
      P=0,               //  Sequence-counter, starting at 0
      m[]=new int[999],  //  Element-counter array, starting filled with 0s
      t;                 //  Temp-integer to reduce the byte-count
  String e=" Elements ", //  Temp-String " Elements " to reduce byte-count
         r=l<21?         //  If the size of the input-array is 20 or less:
            "The Top "+l+" Array"+e+"\n"
                         //    Start the result-String with 'length' gossip-line
           :             //   Else:
            "";          //    Start the result-String empty
  for(;i<l               //  Loop over the input-array
      ;                  //    After every iteration:
       r+=i>0&&          //     If this is not the first item,
           p(p)>1&p(t=a[i-1])>1?
                         //     and the current and previous items are both primes:
             p+" And "+t+" Were Spotted Together, You Won't Believe What They Did\n":"",
                         //      Append the 'two primes' gossip-line
       m[a[i++]]++)      //     Increase the counter of the current value by 1
    if(p<(p=a[i])        //   If the previous item is smaller than the current:
      P++;               //    Increase the sequence-counter by 1
    else{                //   Else:
      r+=P>2             //    If the sequence-counter is 3 or larger:
          P+e+"Sort Themselves, Find Out What Comes Next\n":"";
                         //     Append the 'sequence' gossip-line
      P=1;}              //    Reset the sequence-counter to 1
  for(;l-->0;            //  Loop over the Element-counter array
      r+=m[l]>1?         //   If this element occurred at least two times:
          "These "+m[l]+e+"Will Blow Your Mind\n":"");
                         //    Append the 'occurrence' gossip-line
  return r;}             //  Return the result

// Separated method to check if the given number is a prime
// If `n` is a prime, it remains the same; if not: either 1 or 0 is returned
int p(int n){for(int i=2;i<n;n=n%i++<1?0:n);return n;}

1
  • все ще гольф, але допомога буде дуже вдячна

JavaScript (Node.js) , 397 байт

a=>a.map(x=>(l<=x?s++:(s>2&&r.push(s+" Elements Sort Themselves, Find Out What Comes Next"),s=1),P(x)&&P(l)&&r.push(l+` And ${x} Were Spotted Together, You Won't Believe What They Did`),c[l=x]=-~c[x]),c=[s=l=r=[]])&&c.map((x,i)=>x>1&&c.indexOf(x)==i&&r.push(`These ${x} Elements Will Blow Your Mind`))&&[...r,...a[20]?[]:[`The Top ${a.length} Array Elements`]]
P=(n,i=1)=>n>1&&++i*i>n||n%i&&P(n,i)

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


Чи можете ви зберегти, замінивши одного символу, наприклад, '!'на ' Elements '(або подібний)?
Джонатан Аллан

Ви не змогли правильно впоратися з монотонно зростаючим правою рукою без зворотного зменшення (посилання, яке ви надаєте, не повинно виводити "6 елементів сортуйте самі, дізнайтеся, що йде далі", оскільки немає "Наступного")
Джонатан Аллан

НедолікThe Top * Array Elements
l4м2

ну це навіть коротший y код у моєму поході відповідь я зробив це так. буде виправлено. @ l4m2 спасибі
DanielIndie

Я не на 100% впевнений, оскільки речення в описі виклику можна інтерпретувати двома способами, але не слід [5,10,5,10]виводити These 2 Elements Will Blow Your Mindдвічі? Я думаю, що складна частина " Роздрукуйте це лише один раз на унікальне число " означає цифри, 5а 10не число N=2. Але, можливо, попросіть ОП перевірити. Якщо друга, ваша реалізація правильна, а три інші відповіді - неправильні. Якщо перша лише ваша реалізація неправильна.
Кевін Кройсейсен

1

JavaScript (Node.js) , 351 350 349 347 байт

a=>a.map((x,i)=>c[s=x>=l?-~s:++s>2&&(t+=s+` Elements Sort Themselves, Find Out What Comes Next
`),P(x)&P(l)&&(t+=l+` And ${x} Were Spotted Together, You Won't Believe What They Did
`),l=x]=-~c[x],t=a[20]?'':`The Top ${a.length} Array Elements
`,c=[s=l=P=(n,i=n)=>n%--i?P(n,i):1/i])+c.map(x=>x>1&&(t+=`These ${x} Elements Will Blow Your Mind
`))&&t

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

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