Число поганих чисел


20

Якщо додатне ціле число має (строго) менше простих коефіцієнтів (не рахуючи кратності), ніж його наступник та попередник, ми назвемо це числом, яке не відповідає факторам .N>2

Іншими словами, і , де , це число унікальних простих множників .ω(N)<ω(N1)ω(N)<ω(N+1)ω(N)N

Завдання

Ви можете вибрати наступні формати вводу-виводу:

  • Візьміть ціле число і виведіть число N - коефіцієнта, поганого фактора. У випадку, якщо ви виберете цей, може бути 0 або 1 індексованим.NNthN
  • Візьміть натуральне ціле число та виведіть перші -бідні факторні числа.NN
  • Друкуйте послідовність нескінченно.

Ви можете приймати дані та надавати вихід за допомогою будь-якого стандартного методу на будь- якій мові програмування , беручи до уваги, що ці лазівки заборонені за замовчуванням. Це код гольфу, тому виграє найкоротше подання, яке дотримується правил.

Я не включатиму окремі тестові випадки, оскільки методи змагання різні, але ви можете посилатися на перші 100 термінів цієї послідовності, що є OEIS A101934 :

11, 13, 19, 23, 25, 27, 29, 37, 41, 43, 47, 49, 53, 59, 61, 64, 67, 71, 73, 79, 81, 83, 89, 97, 101, 103, 107, 109, 113, 121, 125, 131, 137, 139, 149, 151, 155, 157, 163, 167, 169, 173, 179, 181, 191, 193, 197, 199, 211, 221, 223, 227, 229, 233, 239, 241, 243, 251, 259, 263, 265, 269, 271, 277, 281, 283, 289, 293, 307, 309, 311, 313, 317, 331, 337, 341, 343, 347, 349, 353, 359, 361, 365, 367, 371, 373, 379, 383, 389, 397, 401, 407, 409, 419, 421, 431, 433, 439, 441, 443

Як приклад, зустрічається в цій послідовності, оскільки ω ( 25 ) = 1 (5), ω ( 26 ) = 2 (2 і 13) і ω ( 24 ) = 2 (2 і 3), тому ω ( 25 ) < ω ( 24 ) і ω ( 25 ) < ω ( 26 ) .25ω(25)=1ω(26)=2ω(24)=2ω(25)<ω(24)ω(25)<ω(26)


Чи можу я вивести ведучий n = перед кожним значенням?
Steadybox

@Steadybox Схематичний, але я дозволю це: - /
Містер Xcoder

Я додав його як альтернативну версію.
Steadybox

Відповіді:


7

Брахілог , 21 байт

⟨+₁≡-₁⟩{ḋdl}ᵐ⌋>~↰₂?ẉ⊥

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

Друкує нескінченно.

Пояснення

⟨+₁≡-₁⟩                  Fork: The output of the fork is [Input + 1, Input -1]
       {   }ᵐ            Map:
        ḋdl                (predicate 2) the output is the length of the prime decomposition
                           of the input with no duplicates
             ⌋           Take the minimum result of that map
              >          This minimum is bigger than…
               ~↰₂?      …the output of predicate 2 with Input as input
                  ?ẉ     Write Input followed by a new line if that's the case
                    ⊥    False: backtrack and try another value for Input

5

Желе , 13 12 байт

Cr~ÆvÐṂN⁼Wø#

Друкує перші n бідних факторів.

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

Як це працює

Cr~ÆvÐṂN⁼Wø#  Main link. No arguments.

          ø   Wrap the links to the left into a chain and begin a new chain.
           #  Read an integer n from STDIN and call the chain to the left with
              arguments k = 0, 1, 2, ... until n of them return a truthy value.
              Return those n values of k as an array.
C                 Complement; yield -k+1.
  ~               Bitwise NOT; yield -k-1.
 r                Range; yield [-k+1, -k, -k-1].
     ÐṂ           Yield those elements of [-k+1, -k, -k-1] for which the link to
                  the left returns the minimal value.
   Æv                 Count the number of unique prime factors.
                      Note that, for a negative argument, Æv counts -1 as well, and
                      0 is counted as a/the factor of 0. Negating the the arguments
                      eliminates the edge case 1 (no factors), which would be a
                      false positive otherwise.
                  For a factor-poor number, this yields [-k].
       N          Take the negatives of the resulting integers.
         W        Wrap; yield [k].
        ⁼         Test the results to both sides for equality.

5

Python 2 , 123 119 байт

q=lambda n:sum(n%i<all(i%j for j in range(2,i))for i in range(2,n+1))
i=2
while 1:
 i+=1
 if q(i-1)>q(i)<q(i+1):print i

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


@FryAmTheEggman дякую! Навіть те, що я не використовував вашу пропозицію, це надихнуло мене на інший підхід, який врятував 4 байти: D
Rod

Приємно! Я був впевнений, що є спосіб уникнути двох негарних лямбд :)
FryAmTheEggman

4

MATL , 26 24 22 байт

`T@3:q+YFg!sdZSd0>?@QD

Друкує послідовність нескінченно.

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

Пояснення

`         % Do...while loop
  T       %   Push true. Will be used as loop condition
  @       %   Push (1-based) iteration index, k 
  3:q     %   Push [1 2 3] minus 1, that is, [0 1 2]
  +       %   Add, element-wise. Gives [k k+1 k+2]
  YF      %   Exponents of prime-factor decomposition. Gives a 3-row matrix
  g       %   Convert to logical: non-zero numbers become 1
  !s      %   Transpose, sum of each column. Gives a row vector of 3 elements, 
          %   which are the number of unique prime factors of k, k+1 and k+2 
  d       %   Consecutive differences. Gives a row vector of 2 elements
  ZS      %   Sign: replaces each number by -1, 0 or 1
  d       %   Consecutive difference. Gives a single number
  0>      %   Is it positive?
  ?       %   If so
    @Q    %     Push k+1
    D     %     Display
          %   End (implicit)
          % End (implicit). The stack contains true, which (is consumed and)
          % causes an infinite loop

3

Лушпиння , 22 байти

f(ΠtSM<←ṙ1mȯLup§…←→)tN

Друкує послідовність нескінченно, спробуйте в Інтернеті або перегляньте перший N !

Крім того, §oΛ>←t можна використовувати замість цього ΠtSM<←.

Пояснення

f(                  )tN  -- filter the tail of the naturals ([2,3…]) by:
  ΠtSM<←ṙ1m(Lup)§…←→     -- | takes a number as argument, example 11
                §…       -- | range of..
                  ←      -- | | the argument decremented (10)
                   →     -- | | to the argument incremented (12)
                         -- | : [10,11,12]
          m(   )         -- | map the following (example on 12) ..
              p          -- | | prime factors: [2,2,3]
             u           -- | | deduplicate: [2,3]
            L            -- | | length: 2
                         -- | : [2,1,2]
        ṙ1               -- | rotate by 1: [1,2,2]
    SM<                  -- | map the function (< X) over the list where X is ..
       ←                 -- | | the first element (1)
                         -- | : [0,1,1]
   t                     -- | tail: [1,1]
  Π                      -- | product: 1
                         -- : [11,13,19,23,25,27,29…

3

Піт , 14 байт

.f!-.ml{Pb}tZh

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

Спочатку це було пропозицією щодо відповіді Допаппа , але вони сказали мені опублікувати його окремо.

Як це працює?

.f! -. ml {Pb} tZh | Повна програма. Бере вхід з STDIN, виводить перші N в STDOUT.

.f | (var: Z) Виведіть перші N значень, які задовольняють присудок.
          } тЖ | Створює список [Z - 1, Z, Z + 1].
    .m | (var: b) Візьміть елементи з мінімальним значенням функції.
        Pb | Основні фактори b.
      l {| Дублікат, отримайте довжину.
               | Що стосується бідних факторів, то це піднімається в одиночне.
   - | Видаліть Z від цього.
  ! | Логічне заперечення.

3

Haskell, 105 86 байт

Завдяки @Wheat Wizard, @Bruce Forte та @Laikoni за збереження 19 байт.

[n|n<-[2..],d n<d(n-1),d n<d(n+1)] d x=[1|n<-[1..x],x`rem`n<1,all((>0).rem n)[2..n-1]]


при використанні rem ==0і /=0можуть бути пов'язані з <1і >0відповідно.
Пшеничний майстер

Немає необхідності в letвизначенні dяк допоміжної функції добре (див. Посібник з правил гольфу ). Також sumможна опустити, порівняння працює однаково у списках. 86 байт: Спробуйте в Інтернеті!
Лайконі

2

Октава ,  87   83  79 байт

Дякуємо @Cows quack за збереження байта і спасибі @Luis Mendo за збереження трьох шести байтів!

f=@(n)nnz(unique(factor(n)));n=9;while++n if[f(n-1) f(n+1)]>f(n)disp(n);end;end

Друкує послідовність нескінченно.

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

73 байти з провідними n =перед кожним значенням:

f=@(n)nnz(unique(factor(n)));n=9;while++n if[f(n-1) f(n+1)]>f(n)n end;end

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


Я думаю, що функція fможе стати f=@(n)length(unique(factor(n)))на один менший байт.
Крітіксі Літос

2

05AB1E , 14 13 байт

Виводить число n-фактор-бідне (1-індексований)

µ3LN+Íf€gÀć›P

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

Пояснення

µ                 # loop over N (1,2,3, ...) until counter equals input
 3L               # push the range [1,2,3]
   N+             # add current N
     Í            # subtract 2
      f           # get unique prime factors of each
       €g         # get length of each factor list
         À        # rotate left
          ć       # extract the head
           ›      # check if the remaining elements are strictly greater
            P     # product
                  # if 1, increment counter
                  # implicitly output final N

1
Я збирався запропонувати перейти µ, тому я думаю, що я просто зазначу свою альтернативу - N<N>Ÿможу замінити 3LN+Í, якщо це допоможе.
Містер Xcoder

@ Mr.Xcoder: Так ®XŸN+само працює. Або 0®X)N+в такому випадку Àне знадобиться. На жаль, всі вони опиняються в одному байті.
Емінья

1

Pyth, 30 25 байт

#=hTI&>l{PhTKl{PT>l{PtTKT

Це мій перший справжній гольф Pyth, тому будь-які коментарі дуже вдячні.

Велика подяка Xcoder!

Пояснення

#                         | Loop until error
 =hT                      | Add one to T (initially 10)
    I&                    | If both...
      >l{PhTKl{PT         | The number of unique prime factors of T+1 is greater than that of T (store in K) 
                 >l{PtTK  | And the number of unique prime factors of T-1 is greater than K (from before)
                        T | Then implicitly print T

ТІО .


14 байт: .f!-.ml{Pb}tZh(друкує перше n) ( .fотримує перші n значень, які задовольняють умові над [1,2,3,...]і використовує змінну Z, }tZhгенерує цілий діапазон [Z - 1 ... Z + 1], .mповертає список елементів з мінімальним значенням функції (з b), l{Pbотримує кількість відокремлених подільників, -відкидає Zзі списку, !застосовує логічне заперечення)
Містер Xcoder

1
@ Mr.Xcoder, уау, я не думаю, що незабаром я отримав би це! Чи не скажете ви, що це заслуговує власної відповіді?
Даніель

@Dopapp Добре тоді, я розмістив його окремо. +1 Ласкаво просимо в гольф Pyth!
Містер Xcoder

25 байт, використовуючи ваш підхід.
Містер Xcoder

Ні. hє +1, tє -1, поки Kє змінною, якій присвоюється без =. Наприклад, K4призначає Kна 4. Потім ви можете отримати доступ до нього за допомогою K.
Містер Xcoder

1

JavaScript (ES6), 94 байти

Повертає число N-бідних факторів, 0-індексується.

f=(i,n=9)=>(P=(n,i=k=1)=>++k>n?0:n%k?P(n,1):i+P(n/k--,0))(n)>P(++n)&P(n)<P(n+1)&&!i--?n:f(i,n)

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

Як?

Спочатку визначимо функцію P (), яка повертає кількість унікальних простих коефіцієнтів даного цілого числа.

P = (                   // P = recursive function taking:
  n,                    //   n = input number to test
  i =                   //   i = flag to increment the number of prime factors
  k = 1                 //   k = current divisor
) =>                    //
  ++k > n ?             // increment k; if k is greater than n:
    0                   //   stop recursion
  :                     // else:
    n % k ?             //   if k is not a divisor of n:
      P(n, 1)           //     do a recursive call with n unchanged and i = 1
    :                   //   else:
      i +               //     add i and
      P(n / k--, 0)     //     do a recursive call with n / k and i = 0; decrement k

Код упаковки тепер звучить як:

f = (                   // given:
  i,                    //   i = input index
  n = 9                 //   n = counter
) =>                    //
  P(n) > P(++n) &       // increment n; if P(n - 1) is greater than P(n)
  P(n) < P(n + 1) &&    // and P(n) is less than P(n + 1)
  !i-- ?                // and we have reached the correct index:
    n                   //   return n
  :                     // else:
    f(i, n)             //   go on with the next value

1

Japt , 29 27 26 байт

Не зовсім задоволений цим, але, принаймні, це краще, ніж моя перша спроба, яка була понад 40 байт!

Виводить Nчисло номер у послідовності, 1-індексований.

È=Jõ_+X k â ÊÃé)e>Xo)«´U}a

Спробуй це


Пояснення

Неявне введення цілого числа U.

È                       }a

Повертайте перше ціле число, Xяке повертає істинне, коли воно проходить через наступну функцію.

=Jõ             )

Присвоїти масив [-1,0,1]в X.

 _+X      Ã

Передайте кожен елемент цього масиву через функцію, яка спочатку додає поточне значення X.

k â Ê

Отримайте довжину ( Ê) унікальних ( â) простих факторів ( k) результату.

é

Поверніть отриманий масив праворуч.

e>Xo)

Попустіть ( o) останній елемент з Xі перевірте, чи всі елементи, що залишилися, більше за нього.

«´U

Якщо так, декремент Uі перевірте, чи дорівнює він 0.




0

Чисто , 130 123 117 байт

import StdEnv
?n=[1\\q<-[p\\p<-[2..n]|and[gcd p i<2\\i<-[2..p-1]]]|n rem q<1]
f=[n\\n<-[3..]| ?n<min(?(n-1))(?(n+1))]

Зрівнює до нескінченної кількості доданків послідовності. Оскільки це все вкладене розуміння, воно не може дуже добре скористатися скороченням графіків, і це досить повільно, навіть для такого поганого алгоритму.

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


0

APL NARS, 124 байти, 62 символи

{(⍵>1E4)∨⍵≤0:¯1⋄x←9+⍳10×⍵⋄⍵↑(∊{v←⍴∘∪∘π¨⍵+2-⍳3⋄2=+/v>2⌷v}¨x)/x}

Він повинен повернути відповідь до 1E4, потім повернути -1 помилку; припустимо, 9..10аргумент має правильні цифри; тест:

  z←{(⍵>1E4)∨⍵≤0:¯1⋄x←9+⍳10×⍵⋄⍵↑(∊{v←⍴∘∪∘π¨⍵+2-⍳3⋄2=+/v>2⌷v}¨x)/x}  
  z 0
¯1
  z 1
11 
  z 20
11 13 19 23 25 27 29 37 41 43 47 49 53 59 61 64 67 71 73 79 

4
близько 150 байт?
Кудлатий

@Shaggy так, це було одне приблизне значення; але + - це правильно для гольфів ...
RosLuP

На мій підрахунок, оцінка тут становить 147 байт, а не 152 (кількість символів не має значення). Подальше читання: codegolf.meta.stackexchange.com/q/9428/58974
Shaggy

@Shaggy число 152 буде розміром у байтах одного файлу, що містить лише той код (скопіюйте минуле, збережіть цей код у документі блокнота (Window) та спостерігайте за "властивістю" цього файлу)
RosLuP

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