int array[] = new int[9];//用来存放已经生成的数字
for(int i=0;i<10;i++){
int j = (int)(Math.random()*100);
if(j!==0){
int index = 0;
//分别取出array中的值与生成的值比较,如果不重复则保存到数组中
for(int k=0;k
array[i] = j;
}
}
}else{
i--;
}
}
数组array中的是随机生成的10个100以内的数,没有调试,需要自己调试一下。
粗略的看了其他楼的答案,虽然大部分都能实现,但没有精妙的地方,而好的程序在于精妙,这样才能执行的更快速。我看了我6L的,说实话,他的程序还不错,只是他忽略了一点,他的循环只有一次,而如果数字有重复的情况下,SET就很难存到 10 个数字,不信的话,楼主可以吧他程序里的 100 改成 20 试试,问题就很明显了。
以下是我随手写的,相比6L,显得好多了。
public class Test2 {
public static void main(String[] args){
Random ran = new Random();
Set
while(set.size()==10?false:true){
int num = ran.nextInt(100)+1;
set.add(num);
}
Iterator
int count = 0;
while(it.hasNext()){
System.out.println("第"+ ++count +"个随机数 =="+it.next());
}
}
}
public void test2(){
Random ran = new Random();
Set
int []num = new int[10];
for(int i=0;i
set.add(num[i]);
}
Iterator
while(it.hasNext()){
System.out.println(it.next());
}
}
set集合是自动排重的。
import java.lang.Math;
public class leibi {
private Math mate;
public static void main(String[] args) {
int[] b=new int[10];
for(int i=0;i
for(int j=0;j if((i!=j)&&b[i]==b[j])
b[i]=(int) (Math.random()*100);
}
}
for(int i=0;i
}
}
}
import java.util.Set;
import java.util.TreeSet;
public class Hello {
@SuppressWarnings({ "unchecked", "rawtypes" })
public static void main(String[] args) {
Set set = new TreeSet
while(true){
int a = (int)Math.floor(Math.random() * 100);
if(a > 0 && a <= 100){
set.add(a);
if(set.size() == 10){
break;
}
}
}
System.out.println(set);
}
}