課題へのリンク: http://i.imgur.com/fc86hG9.png
一連の数値を取り、それらをループなしで配列に適用する方法を見分けるのに少し苦労しています。それだけでなく、それらを比較するのに少し苦労しています。私がこれまでに書いたことは次のとおりです。
import java.util.Scanner;
public class Lottery {
public static void main(String[] args) {
int userInputs[] = new int[5];
int lotteryNumbers [] = new int[5];
int matchedNumbers =0;
char repeatLottery = '\0';
Scanner in = new Scanner (System.in);
do{
System.out.println("Enter your 5 single-digit lottery numbers.\n (Use the spacebar to separate digits): ");
for(int i = 0; i <5; i++ )
userInputs[i] = in.nextInt();
System.out.println("Your inputs: ");
printArray(userInputs);
System.out.println("\nLottery Numbers: ");
readIn(lotteryNumbers);
for(int i=0; i<5; i++) {
System.out.print(lotteryNumbers[i] + " ");
}
matchedNumbers = compareArr(userInputs, lotteryNumbers);
System.out.println("\n\nYou matched " + matchedNumbers + " numbers");
System.out.println("\nDo you wish to play again?(Enter Y or N): ");
repeatLottery = in.next().charAt(0);
}
while (repeatLottery == 'Y' || repeatLottery == 'y');
}
public static void printArray(int arr[]){
int n = arr.length;
for (int i = 0; i < n; i++) {
System.out.print(arr[i] + " ");
}
}
public static void readIn(int[] List) {
for(int j=0; j<List.length; j++) {
List[j] = (int) (Math.random()*10);
}
}
public static int compareArr (int[] list1, int[] list2) {
int same = 0;
for (int i = 0; i <= list1.length-1; i++) {
for(int j = 0; j <= list2.length-1; j++) {
if (list1[i] == list2[j]) {
same++;
}
}
}
return same;
}
}
お気づきのとおり、入力行の処理方法がよくわからないため、入力行をコメントアウトしました。それらを配列に入れれば、かなり簡単に比較できるはずです。これは、配列を扱う最初の割り当てであり、クラス期間が 1 つしかないということは、少し詳細に思えると思います。ですから、私の無知をお許しください。:P
編集:
最後に数字を比較する新しい方法を追加しましたが、問題は、位置ごとではなく、一般的にそれらを比較することです。それが今の大きな問題のようです。