Katkıda bulunmak istiyorsanız, lütfen aşağıdaki adımları takip edin:
- Projeyi forklayın
- Kendi dalınızı oluşturun (
git checkout -b ozellik/dal-adi) - Çözmek istediğiniz algoritma dizinine geliniz.(algorithm-1,algorithm-2 vb.) Bu dizinde karşınıza programlama dilleri klasörleri çıkacaktır. Çözüm yapacağınız programlama dilinin dosya dizinine gelin. ( C#,Rust vb.)
- İlgili algoritma için çözümünüzü repo içerisinde kaç tane çözüm varsa ona göre isimlendirin. Eğer 2 adet çözüm varsa kendi çözümünüzü "solution-3.cs" şeklinde kaydedebilirsiniz.Bu numaralandırma şekliyle çözümleri daha derli toplu tutmayı hedefliyoruz. Farklı isimlendirmeler ile gönderilen PR 'lar otomatik olarak reddedilecektir.
- Değişikliklerinizi commit edin (
git commit -am 'Değişiklikleri açıklayan mesaj') - Dalınıza push yapın (
git push origin ozellik/dal-adi) - Bir Pull Request oluşturun
2 x 3'lük bir tahta üzerinde, 1'den 5'e kadar etiketlenmiş beş adet kutu ve 0 ile temsil edilen boş bir kare bulunmaktadır. Bir hamle, 0 ve 4 yönlü bitişik bir sayıyı seçip değiştirmekten oluşur.
Tahta durumu, tahta [[1,2,3],[4,5,0]] olduğunda çözülmüş sayılır.
Verilen tahta üzerindeki puzzle durumuna göre, tahta durumunun çözülmesi için gerekli en az hamle sayısını döndürün. Eğer tahta durumunun çözülmesi mümkün değilse, -1 döndürün.
Girdi: board = [[1,2,3],[4,0,5]]
Çıktı: 1
Açıklama: Bir hamlede 0 ve 5'i değiştirin.
Girdi: board = [[1,2,3],[5,4,0]]
Çıktı: -1
Açıklama: Hiçbir hamle sayısı tahtayı çözülmüş hale getirmeyecektir.
Girdi: board = [[4,1,2],[5,0,3]]
Çıktı: 5
Açıklama: 5, tahtayı çözen en küçük hamle sayısıdır.
Bir örnek yol:
- hamleden sonra: [[4,1,2],[5,0,3]]
- hamleden sonra: [[4,1,2],[0,5,3]]
- hamleden sonra: [[0,1,2],[4,5,3]]
- hamleden sonra: [[1,0,2],[4,5,3]]
- hamleden sonra: [[1,2,0],[4,5,3]]
- hamleden sonra: [[1,2,3],[4,5,0]]
Kısıtlamalar:
board.length == 2 board[i].length == 3 0 <= board[i][j] <= 5 Her board[i][j] değeri benzersizdir.
Bu proje MIT Lisansı ile lisanslanmıştır - daha fazla bilgi için LİSANS dosyasına bakın.


