Это Паскаль Прайм?

18

Хорошо известно, что нечетные простые числа появятся в треугольнике Паскаля ровно дважды. Однако не все числа, которые появляются ровно дважды в треугольнике Паскаля, являются простыми. Мы будем называть эти числа простыми числами Паскаля.

Простые числа Паскаля - это составные числа, которые появляются ровно дважды в треугольнике Паскаля. Первые несколько простых чисел Паскаля

4, 8, 9, 12, 14, 16, 18, ...

Ваша задача - взять положительное целое число n в качестве входных и выходных значений true или false, в зависимости от того, является ли n простым числом Паскаля или нет. Это код-гольф, поэтому выигрывает самая короткая программа!

Просто Красивое Искусство
источник
Соответствующий OEIS.
Мартин Эндер
2
Можем ли мы вывести True, если это не простое число Паскаля, и false, если оно есть?
января 18
Эта последовательность OEIS последовательность A002808 пересечения «с с OEIS последовательности A137905 .
полностью человек
@cairdcoinheringaahing нет, это должно быть в соответствии с данным требованием.
Просто Красивое Искусство
Я удивлен, что никто не опубликовал ответ на Паскале. Я буду, если я получу время (и если я смогу найти мой старый компилятор Паскаля).
Manassehkatz-Восстановить Монику

Ответы:

10

Wolfram Language (Mathematica) , 45 байт

CompositeQ@#&&Binomial~Array~{#-1,#}~FreeQ~#&

Попробуйте онлайн!

Каждое составное число n появляется ровно дважды в строке n и не может появиться впоследствии. Таким образом, условием для простых чисел Паскаля является то, что они вообще не появляются в первых n-1 строках.

Насколько я могу судить, это короче, чем проверка того, что он появляется ровно дважды в первых n строках, и возможность использовать !PrimeQвместо этого.

Мартин Эндер
источник
4

Python 2 , 93 байта

def f(n):l=[1];exec"(n in l)>=any(n%k<1for k in range(2,n))>q;l=map(sum,zip([0]+l,l+[0]));"*n

Попробуйте онлайн!

Это именованная функция f , которая выводит через код выхода , 0 для простых чисел Паскаля, 1 в противном случае.

Как это работает?

def f(n):l=[1];                       # Define a function f (arg. n) and a list l = [1].
exec"..."*n                           # Execute n times.
(n in l)                              # Boolean: "n is in l?" is greater than...
   >=any(n%k<1for k in range(2,n))    # the boolean: "Is n composite?"?
            >q;                       # If the boolean comparison returns a falsy
                                      # result, then continue on without any difference.
                                      # Otherwise, evaluate the other part of the
                                      # inequality, thus performing "is greater than q".
                                      # Since we have no variable "q", this terminates
                                      # with exit code 1, throwing a "NameError".
l=map(sum,zip([0]+l,l+[0]));          # Generate the next row in Pascal's triangle,
                                      # By zipping l prepended with a 0 with l appended
                                      # with a 0 and mapping sum over the result.

Это в основном проверяет, встречается ли n в первых n - 1 строках треугольника Паскаля или является ли оно простым, и выдает ошибку, если выполняется любое из этих двух условий.

Сохранено 1 байт благодаря ovs .

Мистер Xcoder
источник
93 байта
овс
@ovs: o Это умно! Благодарю.
Мистер Кскодер
4

Желе , 11 10 9 байт

Благодаря:

  • Мартин Эндер за -1 байт! (другой подход, используйте (+1), избегайте использования n2(-2), поэтому -1 в целом.
  • Джонатан Аллан за исправление ошибки.
  • Деннис за еще один байт.
Ḷc€ḶFċ=ÆP

Попробуйте онлайн!

Альтернативный подход , Джонатан Аллан . (недостатки)

----------- Explanation -----------
Ḷ            Lowered range. [0, 1, ..., n-1]
 c€Ḷ           `c`ombination `€`ach with `Ḷ`owered range [0...n-1]
    F        Flatten.
     ċ       Count the number of occurences of (n) in the list.
       ÆP    Returns 1 if (n) is a prime, 0 otherwise.
      =      Check equality.

Пояснение к последней строке:

  • Как указал Мартин Эндер, « nпоявляется дважды в треугольнике Паскаля» эквивалентно « nне появляется в первых n-1строках».
  • Мы хотим вернуть, trueесли число не простое (то есть ÆP == 0), а количество cравно нулю. Из этого мы можем вывести это ÆP == c.
    Можно доказать, что если они равны, то они равны 0, потому что:
    • ÆP вернуть логическое значение, которое может быть только 0 или 1.
    • Если он возвращает 1, то nэто простое число, поэтому он не может появиться в первых n-1строках (то есть, c == 0)
user202729
источник
1не простое число Паскаля; это говорит, что это так.
Джонатан Аллан
Ḷc€ḶFċoÆP¬будет работать, я думаю.
Джонатан Аллан
ċ=ÆPдолжно сработать.
Деннис
К вашему сведению, я нашел недостаток в своем подходе и удалил его.
Джонатан Аллан
Кстати, Ḷcþ`Fċ=ÆPтоже должно работать.
Мистер Кскодер
4

Haskell , 86 84 байта

p=[]:[zipWith(+)(1:x)x++[1]|x<-p]
f n=all((>0).rem n)[2..n-1]==any(elem n)(take n p)

Попробуйте онлайн!

объяснение

Функция pрекурсивно определяет вырожденный треугольник Паскаля:

[]
[1]
[2,1]
[3,3,1]
[4,6,4,1]
[5,10,10,5,1]

Как мы видим (это решение 1несколько особенное), каждое число nпоявляется ровно дважды в n+1строке th, а все элементы последующих строк только nувеличиваются , поэтому нам нужно только проверить, находится ли где-то до nстроки th, чтобы увидеть, элемент дисквалифицирован:

any(elem n)(take(n-1)p)

Теперь у нас есть Trueвсе элементы , которые появляются более чем в два раза ( за исключение 1), поэтому все , что нам нужно, чтобы иметь дефектную isPrimeфункцию , которая возвращает Trueдля 1:

all((>0).rem n)[2..n-1]
ბიმო
источник
4

APL (Dyalog) , 44 34 24 19 байтов

5 байтов сохранено благодаря @Cowsquack

(~0∊⊢|⍨2↓⍳)⍱⊢∊⍳∘.!⍳

Попробуйте онлайн!

Как?

Мы уверены, что ни один не делает

- диапазон 0.. n-1,

⍳∘.! - на декартовом биноме с самим собой

⊢∊- содержать n,

- и не делает

⊢|⍨- nпо модулю каждого элемента

2↓⍳- диапазон 2..n-1

~0∊- не содержать 0(или неделимый)

Уриэль
источник
Преобразование его в поезд (∨/1↓1≠⊢∨⍳)∧(~⊢∊⍳∘.!⍳)короче на два байта
Kritixi Lithos
@ Cowsquack хм Я не заметил, что он стал настолько коротким, что поезд мог бы соответствовать (начался как 40 байтеров). Благодарность!
Уриэль
(0∊⊢|⍨2↓⍳)∧∘~⊢∊⍳∘.!⍳еще два я изменил алгоритм проверки простоты
Kritixi Lithos
@ Cowsquack oo умный. Я никогда не видел такой вариации первичности
Уриэль
Перестановка ~дает (~0∊⊢|⍨2↓⍳)⍱⊢∊⍳∘.!⍳на один байт меньше.
Kritixi Lithos
2

JavaScript (Node.js) , 103 101 байт

n=>(r=x=>[...Array(n).keys(F=n=>n>0?n*F(n-1):1)].every(x))(i=>r(j=>F(i)/F(j)/F(i-j)-n))>r(i=>i<2|n%i)

Попробуйте онлайн!

l4m2
источник
n=>(r=x=>[...Array(n).keys(F=n=>n>0?n*F(n-1):1)].every(x))(i=>r(j=>F(i)/F(j)/F(i-j)-n))>F(n-1)**2%nТориори работает, но на самом деле для небольшого радиуса
l4m2
2

R , 55 байт

function(n)sum(!n%%1:n)>2&!n%in%outer(1:n-1,1:n,choose)

Попробуйте онлайн!

sum(!n%%1:n)>2является составным тестом и outer(1:n-1,1:n,choose)вычисляет строки 0в n-1треугольнике Паскаля, поэтому мы должны убедиться, что nони там не отображаются.

Giuseppe
источник
2

05AB1E , 10 байтов

ÝDδcI¢IpÌQ

Попробуйте онлайн!

объяснение

Ý            # push range [0 ... input]
 D           # duplicate
  δc         # double vectorized command binomial
    I¢       # count occurrences of input
      Ip     # check input for primality
        Ì    # add 2
         Q   # compare for equality

Проверки, которые nвстречаются ровно дважды в первых n + 1 строках треугольника паскалей и не являются простыми.
Сравнение работает, так как в треугольнике нет простых чисел, которые могут встречаться 3 раза.

Emigna
источник
0

Python 2 , 105 104 байта

спасибо пользователю 202729 за -1 байт

a=q=[1];n=input();r=n<4;p=1
for i in range(2,n):q=a+map(sum,zip(q[1:],q))+a;r+=n in q;p*=n%i
print p+r<1

Попробуйте онлайн!

овс
источник
Пара круглых скобок p+rкажется излишней ...
user202729