Üzgünüm, bu soru biraz ezoterik, ama kafamdan çıkaramıyorum!
Arcade oyunu DoDonPachi (ve diğer birçok eski oyun) kullanılan solmaya algoritması bakıyorum:
Birkaç piksel seçmek ve solma süresi boyunca onları izlemek için bir python komut dosyası yazdım. İşte sonuçların temsili bir örneği. Her grubun ilk satırı başlangıç renk değeridir, sonraki her satır geçerli çerçevenin renk değeri ile önceki çerçevenin renk değeri arasındaki farktır.
Starting Value: (132, 66, 189)
Frame 1: [9, 9, 8]
Frame 2: [8, 8, 8]
Frame 3: [8, 8, 8]
Frame 4: [8, 8, 9]
Frame 5: [9, 9, 8]
Frame 6: [8, 8, 8]
Frame 7: [8, 8, 8]
Frame 8: [8, 8, 9]
Frame 9: [9, 0, 8]
Frame 10: [8, 0, 8]
Frame 11: [8, 0, 8]
Frame 12: [8, 0, 9]
Frame 13: [9, 0, 8]
Frame 14: [8, 0, 8]
Frame 15: [8, 0, 8]
Frame 16: [8, 0, 9]
Frame 17: [0, 0, 8]
Frame 18: [0, 0, 8]
Frame 19: [0, 0, 8]
Frame 20: [0, 0, 9]
Frame 21: [0, 0, 8]
Frame 22: [0, 0, 8]
Frame 23: [0, 0, 8]
Frame 24: [0, 0, 0]
Frame 25: [0, 0, 0]
Frame 26: [0, 0, 0]
Frame 27: [0, 0, 0]
Frame 28: [0, 0, 0]
Frame 29: [0, 0, 0]
Starting Value: (132, 0, 0)
Frame 1: [9, 0, 0]
Frame 2: [8, 0, 0]
Frame 3: [8, 0, 0]
Frame 4: [8, 0, 0]
Frame 5: [9, 0, 0]
Frame 6: [8, 0, 0]
Frame 7: [8, 0, 0]
Frame 8: [8, 0, 0]
Frame 9: [9, 0, 0]
Frame 10: [8, 0, 0]
Frame 11: [8, 0, 0]
Frame 12: [8, 0, 0]
Frame 13: [9, 0, 0]
Frame 14: [8, 0, 0]
Frame 15: [8, 0, 0]
Frame 16: [8, 0, 0]
Frame 17: [0, 0, 0]
Frame 18: [0, 0, 0]
Frame 19: [0, 0, 0]
Frame 20: [0, 0, 0]
Frame 21: [0, 0, 0]
Frame 22: [0, 0, 0]
Frame 23: [0, 0, 0]
Frame 24: [0, 0, 0]
Frame 25: [0, 0, 0]
Frame 26: [0, 0, 0]
Frame 27: [0, 0, 0]
Frame 28: [0, 0, 0]
Frame 29: [0, 0, 0]
Starting Value: (165, 156, 222)
Frame 1: [9, 8, 8]
Frame 2: [8, 8, 8]
Frame 3: [8, 8, 8]
Frame 4: [8, 9, 9]
Frame 5: [9, 8, 8]
Frame 6: [8, 8, 8]
Frame 7: [8, 8, 8]
Frame 8: [8, 9, 9]
Frame 9: [9, 8, 8]
Frame 10: [8, 8, 8]
Frame 11: [8, 8, 8]
Frame 12: [8, 9, 9]
Frame 13: [9, 8, 8]
Frame 14: [8, 8, 8]
Frame 15: [8, 8, 8]
Frame 16: [8, 9, 9]
Frame 17: [9, 8, 8]
Frame 18: [8, 8, 8]
Frame 19: [8, 8, 8]
Frame 20: [8, 0, 9]
Frame 21: [0, 0, 8]
Frame 22: [0, 0, 8]
Frame 23: [0, 0, 8]
Frame 24: [0, 0, 9]
Frame 25: [0, 0, 8]
Frame 26: [0, 0, 8]
Frame 27: [0, 0, 8]
Frame 28: [0, 0, 0]
Frame 29: [0, 0, 0]
Starting Value: (156, 90, 206)
Frame 1: [8, 8, 8]
Frame 2: [8, 8, 9]
Frame 3: [8, 8, 8]
Frame 4: [9, 9, 8]
Frame 5: [8, 8, 8]
Frame 6: [8, 8, 9]
Frame 7: [8, 8, 8]
Frame 8: [9, 9, 8]
Frame 9: [8, 8, 8]
Frame 10: [8, 8, 9]
Frame 11: [8, 8, 8]
Frame 12: [9, 0, 8]
Frame 13: [8, 0, 8]
Frame 14: [8, 0, 9]
Frame 15: [8, 0, 8]
Frame 16: [9, 0, 8]
Frame 17: [8, 0, 8]
Frame 18: [8, 0, 9]
Frame 19: [8, 0, 8]
Frame 20: [0, 0, 8]
Frame 21: [0, 0, 8]
Frame 22: [0, 0, 9]
Frame 23: [0, 0, 8]
Frame 24: [0, 0, 8]
Frame 25: [0, 0, 8]
Frame 26: [0, 0, 0]
Frame 27: [0, 0, 0]
Frame 28: [0, 0, 0]
Frame 29: [0, 0, 0]
Gördüğünüz gibi, her karedeki her renk bileşeninden 8 veya 9 çıkarılır. Ayrıca, başlangıç renk değeri her renk bileşeni için farklı olsa da, 9 her zaman 8'den sonra üç kare görünür. Ayrıca her renk bileşeninin 8 veya 9'luk bir farkla 0'a (yani siyah) ulaştığına dikkat edin, keyfi bir kalıntı kalmaz. Bu, 8,8,8,9'luk çıkarılan değer döngüsünün asla kırılmadığı anlamına gelir! (Bu algoritma muhtemelen solmanın son karesinin diğerleri kadar pürüzsüz olmasını sağlamak için yazılmıştır.)
Şimdi, bu beni şaşırtıyor. Hesaplamalarıma göre, işlemi tersine çevirirseniz - yani 8,8,8,9 döngüsünü alın ve 29 çerçevedeki tüm olası kombinasyonları bulmak için toplayın - sadece 52 benzersiz sayı elde edersiniz. Ancak olduğu gibi, her renk bileşeni bu setin bir üyesidir! Bu, renklerin bu solma algoritması için özel olarak seçildiği (olası olmayan) veya solma algoritmasının oyunun renk paletinin etrafında tasarlandığı anlamına gelir. Ama nasıl bir yeryüzünde birileri 8,8,8,9 alırsanız, döngüyü uygun şekilde kaydırırsanız ve paletinizdeki her renk bileşeninden sayıları çıkarmaya devam ederseniz, sonunda her bir renk için 0'a ulaşacağınızı nasıl anlayabilirdiniz? ! Kaçırdığım bir matematik hilesi olmalı. Bu ne?