Date: 2009-10-24 05:58 am (UTC)
Да, немножко мутно написал. Алгоритм там по ходу монтируется, а затем используется. Стоило бы выделить
coinsNumbers n i = (elems i 0 rm, elems i 2 rm)
   where elems i leg = findIndices ((== leg) . (!! i))
         rm = rightMarkers n
возвращающий номера монет, которые нужно класть на чашки весов при i-ом взвешивании
*Coins> coinsNumbers 3 0
([0,1,2,9],[6,7,8,11])
*Coins> coinsNumbers 3 1
([6,7,8,9],[3,4,5,11])
*Coins> coinsNumbers 3 2
([0,3,6,11],[2,5,8,10])
а затем, записав результаты взвешиваний в троичной системе, искать номер фальшивой монетки как индекс соответствующего правого маркера в списке
*Coins> rightMarkers 3
[[0,1,0],[0,1,1],[0,1,2],[1,2,0],[1,2,1],[1,2,2],[2,0,0],[2,0,1],[2,0,2],[0,0,1],[1,1,2],[2,2,0]]
(или левого, превратив нули в двойки и наоборот в случае неудачного первого поиска). Сейчас пост поправлю.
This account has disabled anonymous posting.
If you don't have an account you can create one now.
HTML doesn't work in the subject.
More info about formatting

Profile

deniok: (Default)
deniok

February 2022

S M T W T F S
  12345
6789101112
13141516171819
20212223 242526
2728     

Most Popular Tags

Style Credit

Expand Cut Tags

No cut tags
Page generated Jul. 24th, 2025 08:59 pm
Powered by Dreamwidth Studios