Сполучні преми


26

Виклик:

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

Випробування:

Введення -> Вихід:

252 -> 3
235 -> 2
92 -> 0
31149 -> 2


Чи можуть бути провідні нулі?
Згарб

Так, можуть бути провідні нулі.
poi830

Чи можемо ми взяти список цифр?
LegionMammal978

1
Що станеться, якщо є провідні нулі?
Денніс

Відповіді:


6

JavaScript (ES6), 123 121 120 байт

f=(s,v)=>(p=n=>--n-1?s%n&&p(n):1)(s)||[...s].map((_,i)=>!(n=i&&(a=f(s.slice(0,i)))&&(b=f(s.slice(i)))&&a+b)|n>v?0:v=n)|v

Збережено байт завдяки @Neil!

Пояснення

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

f=(s,v)=>
  (p=n=>--n-1?s%n&&p(n):1)(s) // if s is prime, return 1
  ||[...s].map((_,i)=>        // else for each index in s, split s into 2
    !(n=i&&                   // v = return value (initialised to undefined)
      (a=f(s.slice(0,i)))&&
      (b=f(s.slice(i)))&&
      a+b
    )|n>v?0:v=n               // if i, a, b and n are all > 0 and !(n > v), v = n
  )|v                         // cast v to an integer and return it

// Test
var testCases = [ "252", "235", "92", "3149", "24747" ];
document.write("<pre>" + testCases.map(c => c + ": " + f(c)).join("\n"));


Це я або ви можете змінити , i?(a=...)&&(b=...)&&a+b:0щоб i&&(a=...)&&(b=...)&&a+b?
Ніл

5

MATL , 26 24 байти

0in:"GUtZq@Z^V10ZA=a?x@.

Для деяких тестових випадків потрібно кілька секунд.

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

Пояснення

0       % Push 0
in:     % Take input. Generate array [1,2,...,N] where N is input length
"       % For each. In each iteration the number of used primes is increased
  GU    %   Push input. Convert to number
  tZq   %   Duplicate. Array of primes smaller than the input
  @     %   Push number of primes to bes tested in this iteration
  Z^    %   Cartesian power
  V     %   Convert to 2D array. Each row is a combination of primes
  10ZA  %   Convert each row to base 10, disregarding spaces
  =a    %   Do any of the results equal the input number? 
  ?     %   If so
    x   %     Remove the 0 that's at the bottom of the stack
    .   %     Break for each loop
        %   Implicitly end if
        % Implicitly end for each
        % Implicitly display



2

Bash + coreutils, 169 158 149 байт

c()
{
test $1||echo a
for i in `seq ${#1}`
do factor ${1::$i}|grep -q ': \w*$'&&printf b%s\\n `c ${1:$i}`
done
}
c $1|sort|sed '/a/!d;s/..//;q'|wc -c

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

Тест первинності - це те factor $n | grep -q ': \w*$', що визначає, чи має число точно один простий коефіцієнт.

Ми рекурсивно розділяємо вхід; якщо ліва половина є простим, ми фільтруємо результати правої половини, додаючи по одному до кожного значення. Повернення aна введення нульової довжини припиняє рекурсію.

Нарешті, ми беремо всі результати і сортуємо, щоб знайти найкоротший (ігноруючи будь-які, не маючи на увазі aуспіху); ми повинні видалити два (для вставленого aта для нового рядка), а потім порахувати символи, щоб дати результат.

Тести

$ for i in 252 235 92 31149 111; do echo "$i:"$'\t'"$(./77623.sh $i)"; done
252:    3
235:    2
92:     0
31149:  2
111:    0

Я додав 111до тестів, щоб показати, що 1правильно вважається непростим.


Я збирався запропонувати це . Більшість моїх модифікацій, мабуть, застаріли зараз, але інші все одно повинні працювати.
Денніс

@Dennis - Мені подобається cгенерувати фінал 0. Хоча не так захоплюється рясним твердішим. Ви можете використовувати (варіанти) моєї відповіді як основу для вашої, якщо хочете.
Toby Speight

2

Математика, 142 135 байт

Min[Length/@Select[Join@@@Permutations/@IntegerPartitions@Length[a=#],And@@PrimeQ@*FromDigits/@a~Internal`PartitionRagged~#&]]/.∞->0&

Як бачите, Mathematica не була побудована для цього завдання. Бере список цифр.


Ви можете використовувати And@@замість AllTrue? Слід зберегти 4-5 байт.
CalculatorFeline

Flatten[#,1]=Join@@@#
CalculatorFeline

Гм ... дає помилку і неправильну відповідь на 133 ... ви використовували всі тестові випадки, правда?
CalculatorFeline

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