TelmanStudЭто можно, но надо сначала переписать алгоритм. И для удобства выписывания я тогда обозначу

другой буквой,

.
Имеем:
(1)
, если
;
(2)
, если
;
(3)
, если
все имеют целую часть
, включая тот случай с бесконечностью (
положительные,
нули).
Тут надо дополнить (мне пришлось ещё немного почитать перед тем как уяснить), что если в условиях попадается ноль в знаменателях, но притом не во всех (когда мы закончим вычисления), шаги (1) или (2) стоит делать так, чтобы после них оказывалось меньше таких нулей. То есть если

, то (если

, лучше предпочесть (2)) и (если

, лучше предпочесть (1)), иначе любое сгодится. Если

, то (если

, лучше предпочесть (1)) и (если

, лучше предпочесть (2)), иначе снова подойдёт любое. И оставшиеся варианты аналогично, кроме варианта, когда они все равны нулю.
Найдём
![$[1; 1] + [1; 1, 1, 1] = F(0, 1, 1, 0; 1, 0, 0, 0; [1; 1], [1; 1, 1, 1])$ $[1; 1] + [1; 1, 1, 1] = F(0, 1, 1, 0; 1, 0, 0, 0; [1; 1], [1; 1, 1, 1])$](https://dxdy-02.korotkov.co.uk/f/1/6/b/16b29d9084d8fb7b120b0ef1dd73c7ed82.png)
. Сначала проверяем условие из (3) чтобы не делать лишних движений, но сразу видим, что ничего не будет, потому что

вообще будет неопределённым, если считать. Проверим, пользоваться (1) или (2):

, мы можем делать и то, и то. Сделаем (2).
![$F(1, 0, 0 + 1, 1 + 0; 0, 0, 1 + 0, 0 + 0; [1; 1], [1; 1, 1]) = F(1, 0, 1, 1; 0, 0, 1, 0; [1; 1], [1; 1, 1])$ $F(1, 0, 0 + 1, 1 + 0; 0, 0, 1 + 0, 0 + 0; [1; 1], [1; 1, 1]) = F(1, 0, 1, 1; 0, 0, 1, 0; [1; 1], [1; 1, 1])$](https://dxdy-04.korotkov.co.uk/f/b/2/6/b261fb0bd05f07571633f1a1ea3cd95782.png)
.
Третий шаг опять не получится, и опять

, но так как

, предпочтём (1). [UPD: на самом деле если бы мы сделали (2), осталось бы только два нуля. Я неправильно там выше написал, но оставим как есть. Считать это всё руками очень утомительно, а код писать ради одного примера было бы довольно долго, плюс я бы не увидел пару случаев таким образом.]
![$F(0, 1 + 0, 1, 1 + 1; 0, 0 + 0, 0, 1 + 0; [1], [1; 1, 1]) = F(0, 1, 1, 2; 0, 0, 0, 1; [1], [1; 1, 1])$ $F(0, 1 + 0, 1, 1 + 1; 0, 0 + 0, 0, 1 + 0; [1], [1; 1, 1]) = F(0, 1, 1, 2; 0, 0, 0, 1; [1], [1; 1, 1])$](https://dxdy-04.korotkov.co.uk/f/f/e/a/feadc9e5bcfec66544942a82c6f2a65182.png)
.
С третьим шагом так и не повезёт и нам опять надо делать любой из (1), (2). Сделаем (1) и получим сюрприз: дробь
![$[1]$ $[1]$](https://dxdy-02.korotkov.co.uk/f/d/4/7/d478bbb960d11a0df52c338c436f402a82.png)
кончится (превратится в
![$[] = +\infty$ $[] = +\infty$](https://dxdy-04.korotkov.co.uk/f/f/d/7/fd7f37201539fcd16f3b0dfde761446782.png)
)! Но это на самом деле не страшно, так что сделаем пока этот шаг.
Так мы перейдём к
![$F(1, 1, 2, 3; 0, 0, 1, 1; [], [1; 1, 1])$ $F(1, 1, 2, 3; 0, 0, 1, 1; [], [1; 1, 1])$](https://dxdy-02.korotkov.co.uk/f/d/d/7/dd74f454052ad68673f116cba5ea519082.png)
. Теперь мы не можем делать (1), но мы могли бы продолжать дальше без особых проблем. Вместо этого мы можем избавиться от икса. Так как при

имеем

(предыдущая рассматривавшаяся функция), мы можем дальше продолжить более просто.
Значит теперь
![$F(1, 3; 0, 1; [1; 1, 1])$ $F(1, 3; 0, 1; [1; 1, 1])$](https://dxdy-03.korotkov.co.uk/f/a/2/a/a2a2bf834a9abb31edfb3a482b15efde82.png)
. Мы всё ещё не можем ничего выдать, так что тащим очередной элемент дроби-аргумента.
![$F(3, 1 + 3; 1, 0 + 1; [1; 1]) = F(3, 4; 1, 1; [1; 1])$ $F(3, 1 + 3; 1, 0 + 1; [1; 1]) = F(3, 4; 1, 1; [1; 1])$](https://dxdy-02.korotkov.co.uk/f/d/d/9/dd938120f473f97d677919ed583dc32382.png)
. Мы можем наконец-то выдать

, хотя

. Ну я в таком явном виде это и не видел сформулированным, так что наверно мы ничего страшного не сделали. Выдавая 3, вычтем всё соответствующим образом; имеем теперь
![$[3; F(1, 1; 3 - 3, 4 - 3; [1; 1])] = [3; F(1, 1; 0, 1; [1; 1])]$ $[3; F(1, 1; 3 - 3, 4 - 3; [1; 1])] = [3; F(1, 1; 0, 1; [1; 1])]$](https://dxdy-03.korotkov.co.uk/f/e/5/f/e5f835dc33dc84855ba7bed92895b1ea82.png)
.
Опять шаг (3) не выполним, берём очередной элемент.
![$[3; F(1, 2; 1, 1; [1])]$ $[3; F(1, 2; 1, 1; [1])]$](https://dxdy-02.korotkov.co.uk/f/1/a/7/1a739fb22866a770b9621962a37d859a82.png)
. Теперь мы можем выдать 1, придём к
![$[3; 1, F(1, 1; 1 - 1, 2 - 1; [1])] = [3; 1, F(1, 1; 0, 1; [1])]$ $[3; 1, F(1, 1; 1 - 1, 2 - 1; [1])] = [3; 1, F(1, 1; 0, 1; [1])]$](https://dxdy-02.korotkov.co.uk/f/5/c/5/5c5b8652e201576ca856232acce4755b82.png)
. Тут повторится то, что мы делали только что, и выдастся ещё один раз 1:
![$[3; 1, 1, F(1, 1; 0, 1; [])]$ $[3; 1, 1, F(1, 1; 0, 1; [])]$](https://dxdy-01.korotkov.co.uk/f/0/9/9/09900dd23d9d608d4cf099d817b1340e82.png)
. Тут мы опять можем заметить, что

при

. В итоге выйдет
![$[3; 1, 1, 1]$ $[3; 1, 1, 1]$](https://dxdy-02.korotkov.co.uk/f/1/7/2/172a9537474a804946267f2c513a328482.png)
. Результат по крайней мере правильный, а то я успел испугаться и ошибок в выкладках, и того, что какой-то важный опущеный случай не удастся восстановить.
-- Пт фев 19, 2021 01:21:47 --novichok2018Ну референс же есть на алгоритмы, который сам ТС и нашёл. Там описание правда не из понятнейших, но я вот смог что-то посчитать, не знаю.