i trying finish assignment class have been working on. supposed build battleship game using location class, arraylist, , 2d array against computer. user gets 8 guesses on 5x5 board. attacthing directions below more clear.
i stuck trying check if users guess (in row, col form) matches location object of ship stored in arraylist, however, no matter input, evaluates else, , marks miss (aka places x on board). doing wrong?
directions page 1 directions page 2
here code far:
driver class:
import java.util.random; import java.util.scanner; import java.util.arraylist; public class battleshipdriver { public static void main(string[] args) { //fields char [][] board = new char[5][5]; // game board array arraylist<location> location1 = new arraylist<>(); // array list hold location objects initialboard(board); // prints initial board state random computer = new random(); //create num gen computer placements int row, col; scanner user = new scanner(system.in); //stuff doing things //puts comp's placements in location for(int = 0; <= 4; ++) { row = computer.nextint(5); col = computer.nextint(5); location battleship = new location(row, col); location1.add(battleship); } system.out.println(location1); int turnsleft = 8; int numships = 4; { system.out.println("you have " + turnsleft + " turns left." + "\n" + "there " + numships + " ships left."); system.out.println("please make guess (row, column)"); row = user.nextint(); col = user.nextint(); location userguess = new location(row, col); if(row>4 || col>4 ) { system.out.println("your move invalid."); } else if (board[row][col] == 'x' || board[row][col] == '*') { system.out.println("you have guessed location"); } for(location loc: location1) { if(location1.contains(userguess)) { location1.remove(userguess); board[row][col] = '*'; updateboard(board); system.out.println("you hit ship"); break; } else { board[row][col] = 'x'; updateboard(board); break; } } }while(turnsleft != 0); } //printboard method public static void initialboard(char[][] board) { //for loops iterate through each for(int row = 0; row< board.length; row++) { for(int col = 0; col < board[row].length; col++) { board [row][col] = 'o'; //assigns o signify open water //(this may need change. //will make board o's system.out.print(board[row][col] + " "); } system.out.println(); } } public static void updateboard(char[][] board) { for(int row = 0; row< board.length; row++) { for(int col = 0; col < board[row].length; col++) { system.out.print(board[row][col] + " "); } system.out.println(); } } }
location class:
public class location { private int row; private int col; //getters , setters public int getrow() { return row; } public int getcol() { return col; } public void setrow(int row) { this.row = row; } public void setcol(int col) { this.col = col; } //constructors public location(int row, int col) { this.row = row; this.col = col; } public string tostring() { return row + ", " + col ; } }
i have array list printing contents can input known ship locations see if working properly.
the location class must override equals , hashcode arraylist#contains(...)
work. that's problem , solution.
make row , col final fields , use them check equality , calculate hashcode (you must use invariants this).
something like:
package pkg1; public class location { private final int row; private final int col; // getters , setters public int getrow() { return row; } public int getcol() { return col; } // make field immutable! // public void setrow(int row) { // this.row = row; // } // make field immutable! // public void setcol(int col) { // this.col = col; // } // constructors public location(int row, int col) { this.row = row; this.col = col; } public string tostring() { return row + ", " + col; } @override public int hashcode() { final int prime = 31; int result = 1; result = prime * result + col; result = prime * result + row; return result; } @override public boolean equals(object obj) { if (this == obj) return true; if (obj == null) return false; if (getclass() != obj.getclass()) return false; location other = (location) obj; if (col != other.col) return false; if (row != other.row) return false; return true; } }
in contains(...)
method entry in arraylist api:
returns true if list contains specified element. more formally, returns true if , if list contains @ least 1 element e such (o==null ? e==null : o.equals(e)).
so can see, method uses .equals(...)
method check containment.
Comments
Post a Comment