Взаимные подражатели

17

Пусть положительное целое число , состоящее из п десятичных цифр d 1 , d 2 , . , , , д нAnd1,d2,...,dn . ПозволятьB будет другим положительным целым числом.

Для этой задачи, мы называем в подражатель из B , если существует хотя бы один список положительных целых чисел р 1 , р 2 , . , , , Р п такие , что:AВp1,p2,...,pn

i=1ndipi=B

A иB называютсявзаимными подражателями,еслиA является подражателемB аB является подражателемA .

пример

526 и853 являются взаимными подражателями, потому что:

53+29+63=853

и:

83+51+32=526

Соревнование

С учетом двух положительных целых чисел A и B ваша задача состоит в том, чтобы напечатать или вернуть истинное значение, если A и B являются взаимными копиями или ложным значением в противном случае.

Разъяснения и правила

  • Вы можете взять A и B в любом разумном, однозначном формате (например, целые числа, строки, списки цифр, ...)
  • A иB могут быть равны. Если число является взаимной копией самого себя, оно принадлежит A007532 .
  • Вместо истинных / ложных значений вы можете вернуть два разных согласованных значения.
  • Для 1A<1000 и 1B<1000 ваш код должен быть заполнен в менее чем за одну минуту . Если для более высоких значений требуется слишком много времени, он должен решить их теоретически.
  • Это .

Контрольные примеры

Truthy:
1 1
12 33
22 64
8 512
23 737
89 89
222 592
526 853
946 961
7 2401
24 4224
3263 9734
86 79424
68995 59227
32028 695345

Falsy:
1 2
3 27
9 24
24 42
33 715
33 732
222 542
935 994
17 2401
8245 4153
Arnauld
источник
Похожие случай: 17 2401 -> false. Я почти споткнулся об этом.
Шиеру Асакото

Ответы:

8

Брахилог , 19 байт

ẹ{∧ℕ₁;?↔^}ᵐ².+ᵐ↔?∧≜

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

Выходы true.илиfalse.

объяснение

ẹ                     Split the numbers into lists of digits
 {       }ᵐ²          For each digit
  ∧ℕ₁                 Let I be a strictly positive integer
     ;?↔^                Compute the digit to the power I (which is unknown currently)
            .         Call . the list of those new numbers
            .+ᵐ       Their mapped sum results…
               ↔?     …in the reverse of the input
                 ∧≜   Find if there effectively are values for the numbers in . to satisfy
                        these relationships
Fatalize
источник
2
@Arnauld Исправлено по стоимости 1 байт. Он потерпел неудачу, потому что 2401содержал a, 0который не работал с тем способом, который я проверял, который Iбыл строго положительным (потому что я сопоставил его с обоими Iи цифрой, чтобы сохранить байты)
Fatalize
6

Шелуха , 17 байт

Λλ€⁰mΣΠTṪ^ḣ√⁰d)De

Попробуйте онлайн! Завершает все тестовые случаи под 1000 примерно за 11 секунд.

объяснение

Λλ€⁰mΣΠTṪ^ḣ√⁰d)De  Implicit inputs, say 12 and 33.
                e  Put into a list: [12,33]
               D   Duplicate: [12,33,12,33]
Λ                  Does this hold for all adjacent pairs:
                    (12,33 is checked twice but it doesn't matter)
                    For example, arguments are 33 and 12.
 λ            )     Anonymous function with arguments 33 (explicit) and 12 (implicit).
             d      Base-10 digits of implicit argument: [1,2]
          ḣ√⁰       Range to square root of explicit argument: [1,2,3,4]
        Ṫ^          Outer product with power: [[1,2],[1,4],[1,8],[1,16],[1,32]]
       T            Transpose: [[1,1,1,1,1],[2,4,8,16,32]]
      Π             Cartesian product: [[1,2],[1,4],...,[1,32]]
    mΣ              Map sum: [3,5,...,33]
  €⁰                Is the explicit argument in this list? Yes.

Почему это работает

Если мы имеем B=d1p1++dnpn , где di являюсь цифрами и pi положительные целые числа, то dipiB для всех i , или , что эквивалентно pilogdiB . Мы можем игнорировать случай di1 , поскольку возведение в степень 0 или 1 не меняет его. В моей программе пространство поиска1piB (для соблюдения ограничения по времени; впротивном случаея бы использовал1piB), поэтому, если у нас естьlogdiBB, тогда все в порядке. Еслиdi3, это верно для всех натуральных чиселB, поэтому единственным опасным случаем являетсяdi=2. У нас естьlog2B>BB=823=812A223A=210kkA8B в любом случае, и программа правильно возвращает ложное значение независимо от других вычислений.

Zgarb
источник
Отличный ответ, который заставляет меня хотеть учить шелуху. Два вопроса: 1. Неявный аргумент снова упоминается после его представления. Когда это используется? 2. Не могли бы вы пояснить, почему этот алгоритм эквивалентен тому, который изложен в ОП?
Иона
1
@Jonah 1. Цифровая функция dпринимает неявный аргумент. Я пояснил это в объяснении. 2. Я добавил аргумент в пользу корректности программы.
Згарб
Спасибо ... кстати, часть, которая меня смутила, была «откуда взялся список всех?» ... перечитывая, теперь я понимаю, что это просто потому, что все силы 1 - только одна ....
Иона
4

05AB1E , 26 22 байта

εVтLIàgãεYSym}OIyKå}˜P

Принимает входные данные в виде списка (т.е. [526,853] ).

Попробуйте онлайн или проверьте большинство тестовых случаев в диапазоне[1,999] .

Аналогично моему старому ответу ниже, за исключением того, что [1,n]список жестко закодирован [1,100], и он создает декартовой список дважды, один раз для каждого сопоставления ввода, что является основным узким местом с точки зрения производительности.


Старый 26-байтовый ответ лучше для производительности:

Z©bgL®gãUεVXεYSym}OsN>èå}P

В этой версии я поменял несколько байтов, чтобы улучшить производительность, чтобы она могла легко работать [1,1000]. Тестовые случаи, содержащие числа в диапазоне [1,9999], выполняются в течение приблизительно одной секунды на TIO. Тестовые случаи в диапазоне [10000,99999]примерно 10-15 секунд на TIO. Выше этого будет тайм-аут.

Попробуйте онлайн или проверьте все контрольные примеры с числами в диапазоне[1,9999] .

Объяснение:

Z                 # Push the max of the (implicit) input-list (without popping)
                  #  i.e. [526,853] → 853
 ©                # Store it in the register (without popping)
  b               # Convert to binary
                  #  i.e. 853 → 1101010101
   g              # Take its length
                  #  i.e. 1101010101 → 10
    L             # Pop and push a list [1, n]
                  #  i.e. 10 → [1,2,3,4,5,6,7,8,9,10]
     ®            # Push the max from the register
      g           # Take its length
                  #  i.e. 853 → 3
       ã          # Cartesian product the list that many times
                  #  i.e. [1,2,3,4,5,6,7,8,9,10] and 3
                  #   → [[1,1,1],[1,1,2],[1,1,3],...,[10,10,8],[10,10,9],[10,10,10]]
        U         # Pop and store it in variable `X`
ε              }  # Map both values of the input list:
 V                # Store the current value in variable `Y`
  Xε    }         # Map `y` over the numbers of variable `X`
    Y             # Push variable `Y`
     S            # Convert it to a list of digits
                  #  i.e. 526 → [5,2,6]
      ym          # Take each digit to the power of the current cartesian product sublist
                  #  i.e. [5,2,6] and [3,9,3] → [125,512,216]
         O        # Take the sum of each inner list
                  #  i.e. [[5,2,6],[5,2,36],[5,2,216],...,[125,512,216],...]
                  #   → [13,43,223,...,853,...]
          s       # Swap to push the (implicit) input
           N>     # Push the index + 1
                  #  i.e. 0 → 1
             è    # Index into the input-list (with automatic wraparound)
                  #  i.e. [526,853] and 1 → 853
              å   # Check if it's in the list of sums
                  #  i.e. [13,43,223,...,853,...] and 853 → 1
                P # Check if it's truthy for both both (and output implicitly)
                  #  i.e. [1,1] → 1
Кевин Круйссен
источник
4

Perl 6 , 87 84 69 байт

-15 байт благодаря nwellnhof!

{!grep {!grep $^b,[X+] 0,|map (*X**1..$b.msb+1),$^a.comb},.[0,1,1,0]}

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

Блок анонимного кода, который возвращает True или False.

Объяснение:

{!grep {!grep $^b,[X+] 0,|map (*X**1..$b.msb+1),$^a.comb},.[0,1,1,0]}

{                                                                   }  # Anonymous code block
 !grep    # None of:
                                                          .[0,1,1,0]   # The input and the input reverse
       {!grep       # None of
                  [X+]       # All possible sums of
                       0,|   # 0 (this is to prevent single digit numbers being crossed with themself)
                          map                  ,$^a.comb   # Each digit mapped to
                              (*X**           )  # The power of
                                   1..$b.msb+1   # All of 1 to the most significant bit of b plus 1
                                                 # This could just be b+1, but time constraints...
              $^b,  # Is equal to b
Джо Кинг
источник
@Arnauld, Junction - это Истина / Ложь, как я показал, используя оператор boolify перед выводом. В любом случае, я добавил это к чему-то другому, хотя мог бы сэкономить байт, если бы мог вывести истинное значение для false и наоборот ...?
Джо Кинг,
Благодарю за разъяснение. По поводу инверсии правдивости / ложности: я бы предпочел сказать нет.
Арно
4

JavaScript (Node.js) , 116 92 89 86 83 77 байт

a=>b=>(G=(c,g,f=h=g%10)=>g?c>f&f>1&&G(c,g,h*f)||G(c-f,g/10|0):!c)(a,b)&G(b,a)

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

Ожидайте ввода как (A)(B).

Сиеру Асакото
источник
Строки в порядке. (Я уточнил формат ввода в задании.)
Арно
@Arnauld О, я только что нашел метод, который использует не строку, а 108 байтов.
Шиеру Асакото
2

J , 56 байт

h~*h=.4 :'x e.+/|:>,{x 4 :''<y&*^:(x&>)^:a:y''"+"."+":y'

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

Уу, вложенное явное определение!

Как это устроено

powers =. 4 :'<y&*^:(x&>)^:a:y'  Explicit aux verb. x = target, y = digit
                             y   Starting from y,
               y&*^:     ^:a:    collect all results of multiplying y
                    (x&>)        until the result is at least x
              <                  Box it.

h=.4 :'x e.+/|:>,{x powers"+"."+":y'  Explicit aux verb. x, y = two input numbers
                            "."+":y   Digits of y
                  x powers"+          Collect powers of digits of y under x
                 {            Cartesian product of each item
           +/|:>,             Format correctly and compute the sums
       x e.                   Does x appear in the list of sums?

h~*h  Tacit main verb. x, y = two input numbers
      Since h tests the condition in only one direction,
      test again the other way around (~) and take the AND.
фонтанчик для питья
источник
1

Python 2 , 149 147 143 139 132 118 108 107 106 105 байт

lambda a,b:g(a,b)*g(b,a)
g=lambda a,b:any(g(a/10,b-(a%10)**-~i)for i in(a*b>0)*range(len(bin(b))))or b==0

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

-4 байта, благодаря Веданту Кандой

TFeld
источник
>0могут быть удалены. not a: a<1. b==0:b<1
Ведант Кандой
@VedantKandoi Спасибо, хотя b<0не работает
TFeld
1

J, 68 байт

Я думал, что J будет неплохо выступать здесь, но в итоге все оказалось сложнее, чем я ожидал, и мне понравятся любые предложения для дальнейшего игры в гольф ...

g=.#@#:@[
1 1-:[:(([:+./[=1#.]^"#.1+g#.inv[:i.g^#@])"."0@":)/"1],:|.

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

ПРИМЕЧАНИЕ: мы вычитаем 3 символа из числа TIO, так f=.как основная функция не учитывается

ungolfed

1 1 -: [: (([: +./ [ = 1 #. ] ^"#. 1 + g #.inv [: i. g ^ #@]) "."0@":)/"1 ] ,: |.
Ион
источник