Перейти к содержанию

Рекомендуемые сообщения

Опубликовано
12 часов назад, E.K. сказал:

А если приложить головной мозг, то можно и побыстрее что-то придумать..

Обидно, однако! Цель для меня выбрать инструмент, удобный для меня. Тут я могу работать как с телефона, так и с рабочего ноута. Фильтрация позволяет просмотреть только оставшиеся строки. МоёОфис попробовал - через 15 минут закрыл, когда он завис на создании доп строк.
Да, понятно, что есть комбинации, которые можно применить разом к нескольким вариантам (0^X и 1^Y) и как это применить быстро к инструменту вопрос хороший. Но у меня первоочередная цель сделать перебор всех вариантов, а не сделать быстро - так как дедлайна нет.
 

Опубликовано (изменено)

Думаю, возможна вот такая оптимизационная задумка:
(Базовая идея - конкатенировать первые две цифры набора и дальше рассматривать, что получится)


1. Для наборов, которые начинаются на 70, 71... 98, 99 сводим задачу к такой: получить из четырех оставшися цифр числа 30, 29, 28 ... 2, 1.

Если для каких-то наборов не выходит, то рассматриваем такой набор отдельно. Например, для набора 700200: из 0200 число 30 никак не получить, но 700/((0! + 2)! + 0!) = 100

2. Набор начинается на 66:
6!/6 = 120, задачу можно свести к первому пункту - "набор начинается на 80" (только со знаком минус, надо получить из четырех цифр не 20, а -20)

3. Набор начинается на 69 или 63.
6!/3! = 6!/(v9)! = 6!/6
Сводим к пункту 2


4. Рассматриваем наборы, начинающиеся на 68, 67, 65, 64, 62, 61, 60, 59, 58, 57, 56, 51

5.
- Наборы на 55 сводятся к задаче: "получить из четырех оставщихся цифр четверку", т.к. 5 × 5 = 25

- наборы на 54 - "получить из оставщихся пятерку", 5 × 4 = 20

- наборы на 53 - к пункту 1 для наборов на 75 со знаком минус, т.к 5^3 = 125

- наборы на 52 - к наборам на 55, т.к 5^2 = 25

- наборы на 50 - "получить из 4 цифр двойку"

6. Рассматриваем наборы на 48, 47

7.
- Наборы на 49 и 43 сводятся к пункту 4, наборам на 64, т.к 4^v9 = 4^3 = 64

- наборы 46 - к пункту 4, наборам на 56 со знаком минус, т.к 4! × 6 = 144

- наборы на 45 - к наборам на 80 или к наборам на 54

- наборы на 44 - к наборам на 96, 4! × 4 = 96

- наборы на 42 - к наборам на 48, 4! × 2 = 48

- наборы на 40 и 41 - к наборам на 52, т.к 4! + 0! = 25

8. Рассматриваем наборы на 33, 32, 31, 30

9.
- наборы на 39 сводятся к наборам на 80 или к наборам на 54, т.к. 3!!/9 = 80, 3! × 9 = 54

- наборы на 38 - к наборам на 90 или наборам на 48

- наборы на 37 - к наборам на 42, 3! × 7 = 42

- наборы на 36 - к наборам на 80 со знаком минус, 3!!/6 = 120

- наборы на 35 - к наборам на 56 со знаком минус, 3!!/5 = 144

- наборы на 34 - к наборам на 81 или на 72, 3^4 = 81, 3 × 4! = 72

10. Рассматриваем наборы на 29, 28, 22, 21, 19, 18, 17, 16, 13, 12, 11, 10

- наборы на 27 сводятся к наборам на 72 со знаком минус, 2^7 = 128
- наборы на 26 - к наборам на 64, 2^6 = 64
- наборы на 25 - к наборам на 52
- наборы на 24 - к наборам на 48, 2 × 4! = 48
- наборы на 23 - к наборам на 64, 2^3! = 64

- наборы на 20 - к наборам на 54, "получить из 4 цифрх пятерку"

- наборы на 15 - к наборам на 80 или 79 со знаком минус, 1 + 5! = 121

- наборы на 14 - к наборам на 52,      1 + 4! = 25


Вот такой вот черновой эскиз стратегии.

Изменено пользователем Xandr_5890___
Опубликовано

Ход мысли мне нравится! Я рассуждал похоже, но нашёл, как мне кажется, более оптимальный метод. Поскольку перебирать четырёхзнаки - это как-то не очень...

Опубликовано (изменено)

Можно еще попробовать "разбиение на биграммы", вот набросок стратегии:

1. В начале рассматриваем все пары цифр; для каждой пары составляем множество значений (назовем его "характер биграммы"), которое можно получить с помощью базовых операций:

10 ---> (0,1,2,10,10!) // без учета знака
11 ---> (0,1,2,11,11!)
....
....
99 ---> (0,1,18,81,99...) // еще 9!/9, 9^9 и т.д.

2. Каждый набор разбиваем на биграммы и, опираясь на характеры, смотрим можно ли аддитивно/мультипликативно получить 100:

Набор: 102050 ---> 10|20|50
10 ---> (0,1,2,10..)
20 ---> (0,1,2,3,20..)
50 ---> (0,1,4,5,6,50..)

10 × (2 + 0) × (5 + 0) = 100

3. Если набор состоит из трех различных биграмм и из них "чисто" мультипликативно или "чисто" аддитивно можно получить 100, то такой набор порождает еще 5 наборов, получаемых перестановкой биграмм; такие наборы в дальнейшем проверять не нужно:

102050 ---> 105020, 201050, 205010, 501020, 502010

4. Если сопоставление характеров биграмм не дает результат, то рассматриваем набор отдельно:

Набор: 110100
11 ---> (0,1,2,11,11!)
01 ---> (0,1,2)
00 ---> (0,1,2)

Из биграмм сотня не получается, но:
(11 - 0!) × 10 + 0 = 100

(Не могу утверждать, но чутье подсказывает, что таких наборов не очень много - биграммы часто порождают делителей 100)

 

p.s. захожу с одного устройства, с одной почты, а получается, что с разных аккаунтов...

Изменено пользователем Xandr_5890
Опубликовано
3 часа назад, Xandr_5890 сказал:

p.s. захожу с одного устройства, с одной почты, а получается, что с разных аккаунтов...

Эй, админы! Как так?

 

А цепочка рассуждений меня радует! Но не слишком радует :)

Пожалуйста, войдите, чтобы комментировать

Вы сможете оставить комментарий после входа в



Войти
  • Похожий контент

    • Pager
      Автор Pager
      Собственно в названии темы описана вся проблема. Подскажите, что делать?
×
×
  • Создать...