Ev Kişisel Finans Java Programlama Mücadelesi: Basit Tic-Tac-Toe Programına Array Ekleme

Java Programlama Mücadelesi: Basit Tic-Tac-Toe Programına Array Ekleme

Video: Coding Challenge #147: Chrome Dinosaur Game (with Speech Commands machine learning model!) 2024

Video: Coding Challenge #147: Chrome Dinosaur Game (with Speech Commands machine learning model!) 2024
Anonim

Bu Java programlama zorluğu, bu Tic-Tac-Toe serisindeki önceki zorluklara dayanır ve aslında dizilerden ikisini de kullanma becerilerini test eder.

Java Programlama Zorunluluğunda: Basit Bir Tic-Tac-Toe Oyunu ve Java Programlama Zorluğu: Basit Tic-Tac-Toe Programına Sınıf Ekleme özelliğini kullanarak Tic-Tac-Toe'nin basit oyununu oynamak için bir program yazmaya davet edildiniz.

Bir oyun olarak, Tic-Tac-Toe, oyunun durumunu temsil etmek için bir dizinin kullanılması için çığr atıyor. Diziler olmadan, yönetim kurulunun her bir karesini temsil etmek için ayrı bir değişken kullanmanız gerekir. Bir dizi ile dokuz karenin tamamını temsil etmek için tek bir değişken kullanabilirsiniz.

Bu programlama zorluğu basittir: Programın, dizileri kullanan gelişmiş bir sürümünü yazın. Çözümünüzde en az iki dizi kullanmanız gerekir:

  1. Tahtayı temsil etmek için bir dizi kullanmanız gerekir. Büyük olasılıkla, dokuz elemanlı tek boyutlu bir dizi kullanmak isteyeceksiniz:

    0 | 1 | 2 --- | --- | --- 3 | 4 | 5 --- | --- | --- 6 | 7 | 8
    

    Diğer bir deyişle, sol üstteki kare (A1) dizi öğesi 0'da, sağ alt kare (C3) ise dizi öğesi 8'de saklanır.

  2. Ayrıca sekiz olası üç ardışık vektörü temsil etmek için bir dizi kullanmalısınız.

    Sonra bu diziyi, iki oyuncu da oyunu kazanıp kazanmadığını belirlemek için kullanabilirsiniz. Büyük olasılıkla, bu görev için iki boyutlu bir dizi kullanmak isteyeceksiniz. Dizinin her biri, sırayla belirli bir üçlü vektörün üç dizinini temsil eden sekiz üç elemanlı diziler bulunur.

    Komple dizi aşağıdaki verileri içerecektir:

    0 1 2 3 4 5 6 7 8 0 3 6 1 4 7 2 5 8 0 4 8 2 4 6
    

Bu programın ek bir gereksinimi, sizin için yarattığınız TicTacToeBoard sınıfının bu meydan okuma bir önceki meydan okuma işlemi için oluşturduğunuz sınıfla tamamen uyumlu olmalıdır. Başka bir deyişle, aynı yöntemleri uygulamalıdır. Size kolaylık olması açısından, bu yöntemler aşağıdaki tabloda tekrarlanmıştır.

Bu yöntemler, A1 veya B2 gibi satır-sütun atamalarını kullanan tik-tac-toe board'un karelerine işaret ettiğinden, uygulamanızın bu atamaları dizin numaralarına eşlemesi gerekir. Örneğin, A1 dizesi playAt yöntemine geçirilirse, program dizindeki 0 dizinindeki oyunun işareti olmalı.

TicTacToeBoard Sınıfı
Oluşturucu Açıklama
TicTacToeBoard

Tüm kareler boşalan yeni bir TicTacToeBoard oluşturur.
Yöntem Açıklama
void reset () Her karenin durumunu boşa döndürür.
void playAt (String square, int player) Belirtilen oyuncunun belirtilen karesini (A1, A2, A3, B1, B2, B3, C1, C2 veya C3) işaretler (X için 1, O). Square, izin verilen değerlerden biri değilse, oyuncu 1 veya 2 değilse veya belirtilen kare boş değilse IllegalArgumentException atar.
int isGameOver () Oyunun bitip bitmediğini belirler. Oyun bitmediyse 0, oyun sırasında X, bir oyun kazandığında 2, oyun berabere kalırsa 3 döndürür. Oyun sonlandırma koşulları aşağıdaki gibidir:

1: Herhangi bir satır, sütun veya köşegen tüm X'leri içeriyorsa.

2: Herhangi bir satır, sütun veya köşegen tüm O'ları içeriyorsa.

3: Boş kareler yoksa ne X ne de O kazandı.

int getNextMove () Bilgisayar rakibinin bir sonraki hamlenini temsil eden bir tam sayı döndürür. Bu yöntem, aşağıdaki stratejiye uygun olarak iyi bir hamle seçmek için temel bir çaba göstermelidir:

* Merkez (B2 karesi) boşalırsa, merkez kareyi oynatın.

* Merkez boş değilse, dört köşeden herhangi biri (kareler A1, A3, C1 veya C3) boşsa, köşelerden birini kullanın (hangisi önemsizdir).

* Merkez boş değilse ve köşeler boş değilse kenarlardan birini oynatın (kareler A2, B1, B3 veya C2).

String toString () Tahtanın geçerli durumunu gösteren bir dize döndürür. Dize, bu örnekte olduğu gibi satırları ve ayrı çizgilerini ayrı konsol satırlarında görüntülemek için yeni satır karakterleri içerir:

O | | O

- | - | -

| X |

- | - | -

| X |

Başka bir zorluk olarak, TicTacToeBoard meydan okumasının bu sürümü için, bilgisayar çalar insan rakibe karşı daha akıllı bir strateji kullanmalıdır. Bilgisayarın oyununu aşağıdaki gibi belirleyin:

  1. Bilgisayarın bir sonraki oyuna girmesi mümkünse, bilgisayar kazanan alanda oynamalıdır.

  2. İnsan rakibinin bir sonraki oyununda kazanması mümkünse, bilgisayar, kazanmayı engellemek için insan rakibinin kazanan meydanında oynamalıdır.

  3. Orta kare kullanılabilirse, bilgisayar orta kareyi alacaktır.

  4. Herhangi bir köşe kare mevcutsa, bilgisayar mevcut köşelerden birinde oynamalıdır.

  5. Bilgisayar, kullanılabilen bir kenarlık oynamalıdır.

Bu stratejiyi uygulamak için, her iki oyuncunun da bir sonraki hamleyinde kazanabileceğini belirleyebilecek bir rutini geliştirmeniz gerektiğini unutmayın. Bunu yapmak için, vektörün bir boş kare içerip barındırıp tutmadığını ve diğer iki karenin her birinin aynı rakibe (diğer bir deyişle) karşı işaretler içerdiğini belirlemek için sıradaki üçü vektörlerden her birine bakmanız gerekir., iki X veya iki O'dır).

Bunu, boş bir kareyi temsil etmek için 0, bir X'i temsil etmek için 1 ve bir O'yu temsil etmek için 2'yi kullanarak yapabilirsiniz. Fakat bu oldukça karmaşık bir mantık gerektirir - buna benzer bir şey s1, s2, ve s3 sekiz, üç sıradaki vektörlerden birinin üç karesinin içeriğini içeren tamsayılardır:

if (s1 == 0 & s2 == 1 & s3 == 1) // X can (s2 == 0 & s1 == 1 & s3 == 1) // x s2'de oynayarak kazanabilirse (s3 == 0 & s1 == 1 & s2 == 1) // X, s3'de oynamakla kazanabilir

Yani bir ipucu var: Boş bir kare, bir X ve bir O temsil etmek için 0, 1 ve 2 kullanmak yerine bunun yerine asal sayı 2, 3 ve 5'i kullanın.Ardından, bir oyuncunun belirli bir vektörde kazanabileceğini belirlemek için o vektör için üç değeri çarpın. Sonuç 18 ise, X kazanabilir (233 = 18). Sonuç 50 ise, O kazanabilir (255 = 50).

Ayrıca, bu strateji programın önceki sürümleri için uygulanan strateji üzerinde bir iyileştirme olsa da, yine de mükemmel bir strateji değildir: Yine de doğru sırayla bilgisayarınızı yenebilirsiniz. İlave bir meydan okuma isterseniz, oyunu ekart edilemez yapmak için hangi ek stratejinin gerekli olacağını düşünün ve ardından yeni stratejiyi uygulamak için bir yol düşünün.

Bu zorluğun çözümünü, Java All-in-One Dummies, 4. Edition ürün sayfasındaki İndirilenler sekmesinde bulabilirsiniz.

İyi şanslar!

Java Programlama Mücadelesi: Basit Tic-Tac-Toe Programına Array Ekleme

Editörün Seçimi

Excel 2016 Çalışma Kitabı Tasarlamak - kuklalar

Excel 2016 Çalışma Kitabı Tasarlamak - kuklalar

Tüm Excel 2016 çalışma sayfaları şablonlardan gelmemektedir. Çoğu zaman, belirli çalışma kitaplarının türlerinin üretildiği standart modeller olarak işlev göreceği düşünülen oldukça eşsiz elektronik tablolar oluşturmanız gerekir. Aslında, Excel'de oluşturduğunuz e-tabloların çoğu, bu türden olabilir, özellikle işiniz güvenmiyorsa ...

Excel 2013'teki Veri Formundaki Kayıtları Düzenleme - Veriler

Excel 2013'teki Veri Formundaki Kayıtları Düzenleme - Veriler

Veritabanından sonra yolda gidiyorsanız ve Excel 2013'te kayıt girmekle yetiniyorsanız, veritabanında düzenli bakım yapmak ve düzenlemek için veri formunu kullanmaya başlayabilirsiniz. Örneğin, değiştirmek istediğiniz bir kaydı bulmak için veri formunu kullanabilirsiniz ve sonra düzenlemeleri yapın ...

Bir Excel 2010 Tablosundaki Kayıtları Düzenleme - mankenler

Bir Excel 2010 Tablosundaki Kayıtları Düzenleme - mankenler

Kayıtları düzenlemeye veya silmeye ve masada rutin bakım yapmaya ihtiyaç duyarsınız. Kayıtları el ile çalışma sayfasında düzenleyebilir veya gerekli değişiklikleri yapmak için bir veri formu kullanabilirsiniz. Örneğin, bir veri dosyasını bulmak için veri formunu kullanabilirsiniz ...

Editörün Seçimi

Excel 2010 Grafiğine Veri Tablosu Ekleme - Excel 2010'da çekimser

Excel 2010 Grafiğine Veri Tablosu Ekleme - Excel 2010'da çekimser

Veri tabloları, grafiğin değerlerini grafiğin altındaki bir tabloda görüntüler. 3B grafik kullanırken olduğu gibi, grafiksel bir ekranla birlikte kesin değerleri görmeniz gerekirse yardımcı olurlar. Ayrıca, bazı çizelgelerde okunması zor olan veri etiketlerinden daha uygun olabilirler.

Excel Pivot Tablosuna Hesaplanan Öğe Ekleme - mankenler

Excel Pivot Tablosuna Hesaplanan Öğe Ekleme - mankenler

ÖğEleri bir Excel pivot tabloya ekler. Şimdi, açıkçası, hesaplanan bir öğe eklemek genelde mantıklı değil. Pivot tablolarınız için, eksiksiz, zengin bir Excel listesinden veya bazı veritabanlarından veri aldıysanız, öğe miktarlarını hesaplayarak veriler oluşturmak, biraz goofy'den daha fazlasını gerektirir. Ancak, ...

Editörün Seçimi

Ağınızı bir Güvenlik Testi için Nasıl Eşleştirilir - daha önce ağınızı haritalamanın parçası olarak mankenler

Ağınızı bir Güvenlik Testi için Nasıl Eşleştirilir - daha önce ağınızı haritalamanın parçası olarak mankenler

Güvenlik testi veya etik bir kesmek gerçekleştirirken, halka açık veritabanlarını ve kaynaklarını arayarak başkalarının sisteminiz hakkında ne bildiğini öğrenebilirsiniz. WHOIS aramaları En iyi başlangıç ​​noktası İnternet'te bulunan araçlardan herhangi birini kullanarak bir WHOIS araması gerçekleştirmektir. Içinde ...

Bir Ağdaki Spam'i En Düşük Düzeye Getirme - AYAKLAR

Bir Ağdaki Spam'i En Düşük Düzeye Getirme - AYAKLAR

Hiçbir antispam programı mükemmel değildir; belirli bir miktarda spam'ın gelen kutunuza geçmesini bekleyin. Alınmayan spam miktarını en aza indirgemek için siz (ve kullanıcılarınızın) aklınızda tutmanız gereken bazı ipuçları: Şifrenizi isteyen veya ...

Güvenlik Testi Sonuçlarını Birlikte Götürmek İçin - Güvenlik testi verileriniz olduğunda yalanlar

Güvenlik Testi Sonuçlarını Birlikte Götürmek İçin - Güvenlik testi verileriniz olduğunda yalanlar

- Belgelenen ekran görüntülerinden ve manuel gözlemlerden, kullandığınız çeşitli güvenlik açığı tarayıcıları tarafından üretilen detaylı raporlara kadar - ne yapıyorsunuz? Belgelerinizi ince dişli bir tarakla incelemeniz ve öne çıkan tüm alanları vurgulam