Pytanie w książce:
Napisz pętlę, która wypełnia wartości tablic dziesięcioma liczbami losowymi od 1 do 100. Napisz kod dla dwóch zagnieżdżonych pętli, które wypełniają wartości dziesięcioma różnymi liczbami losowymi od 1 do 100.
Moje pytanie: Dlaczego wymaga to zagnieżdżonej pętli?
Mój kod:
import java.util.Arrays;
import java.util.Random;
public class ArrayPractice
{
public static void main(String[] args)
{
Random random = new Random();
int[] a = new int[10];
int i;
for (i = 0; i < 10; i++)
{
a[i] = 1 + random.nextInt(100);
System.out.print(a[i]+ " ");
}
}
Odpowiedzi:
1 dla odpowiedzi № 1Pamiętaj, że nie musisz importować macierzy tylko po to, aby używać macierzy.
Do tej pory możesz sprawdzić istniejące wartości rnd w tablicy i zmniejszyć licznik zewnętrznej pętli, gdy tylko znajdziesz wartość powtarzającą się:
import java.util.Random;
public class ArrayPractice
{
public static void main(String[] args)
{
Random random = new Random();
int[] a = new int[10];
for (int i = 0; i < 10; i++)
{
int rnd = 1 + random.nextInt (100);
a[i] = rnd;
System.out.print (a [i] + " ");
for (int j = 0; j < i; ++j)
{
if (a[j] == rnd) --i;
}
}
}
}
1 dla odpowiedzi nr 2
import java.util.Arrays;
import java.util.Random;
public class ArrayPractice {
public static void main(String[] args) {
Random random = new Random();
int[] array = new int[10];
int index = 0;
while(index < array.length){
int number = 1 + random.nextInt(100);
boolean found = false;
for (int i = 0; i < index; i++) {
int elm = array[i];
if (elm == number) {
found = true;
break;
}
}
if(!found){
array[index++] = number;
}
}
System.out.print(Arrays.toString(array));
}
}