求助:那位仁兄帮我看看下面是不是死循环啊

udf250 2010-03-22 06:45:55
//生成99个不同的数,包括0
public class PanDuan{
public static void main(String args[]){
int array[] = new int[99];
int i,j,a,n,k=0;

for(i=0;i<99;i++){
array[i] = 0; //数组初始化
}

for(i=1;i<99;i++){
for(j=0;j<i;j++){
a = (int)(100*Math.random()); //生成一个随机数a,0<a<100
//判断前i-1个数是否与第i个数相同,如果不同,执行k++
for(n=0;n<=i;n++){
if(array[n]!=a){
k++;
}
}
if(k==i){
array[i] = a;//如果k==i 则array[i] = a
}
else{
j = 0;
}
}
}

for(i=0;i<99;i++){
System.out.println(array[i]);
}
}
}
...全文
143 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
cbsoftlover 2010-03-23
  • 打赏
  • 举报
回复
信仰Hash
cbajing 2010-03-23
  • 打赏
  • 举报
回复
............
[Quote=引用 4 楼 lancekoo 的回复:]
Java code

import java.lang.Class;

public class StudentHome {
public static void main(String args[]) {
int array[] = new int[99];
int i, j, a = 0, n, k = 0;

for ……
[/Quote]
tjb1216 2010-03-23
  • 打赏
  • 举报
回复
5楼很强大
ifrancis 2010-03-23
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 keeya0416 的回复:]
可以借用HashSet的特性;

Java code

public class Test {
public static void main(String args[]) {
HashSet<Integer> set = new HashSet<Integer>();
while(set.size() < 100){
……
[/Quote]学习了
guangmingdeshenju 2010-03-23
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 lancekoo 的回复:]
Java code

import java.lang.Class;

public class StudentHome {
public static void main(String args[]) {
int array[] = new int[99];
int i, j, a = 0, n, k = 0;

for ……
[/Quote]
洗牌算法也不错
哈希表最好,不过那里是100,不是1000哦。
keeya0416 2010-03-22
  • 打赏
  • 举报
回复
可以借用HashSet的特性;

public class Test {
public static void main(String args[]) {
HashSet<Integer> set = new HashSet<Integer>();
while(set.size() < 100){
set.add((int)(1000 * Math.random() - 1));
//生成的是99个 1000 以内(含零)的整数;
}
for(Integer i : set){
System.out.print(i + " ");
}
}
}
}

  • 打赏
  • 举报
回复

import java.lang.Class;

public class StudentHome {
public static void main(String args[]) {
int array[] = new int[99];
int i, j, a = 0, n, k = 0;

for (i = 0; i < 99; i++) {
array[i] = 0; // 数组初始化
}

for (i = 1; i < 99; i++) {
a = (int) (100 * Math.random()); // 生成一个随机数a,0<a<100
for(j = 0; j <= i; j++) {
if(array[j] != a) {
k++;
}
}
if(k == (i+1)){
array[i] = a;
k = 0;
}

else {
--i;
k = 0;
}

}

for (i = 0; i < 99; i++) {
if(i%20 == 0)
System.out.println();
System.out.print(array[i] + " ");

}
}
}


错了,上面得少了一个k=0,这个是对的
  • 打赏
  • 举报
回复

public class StudentHome {
public static void main(String args[]) {
int array[] = new int[99];
int i, j, a = 0, n, k = 0;

for (i = 0; i < 99; i++) {
array[i] = 0; // 数组初始化
}

for (i = 1; i < 99; i++) {
a = (int) (100 * Math.random()); // 生成一个随机数a,0<a<100
for(j = 0; j <= i; j++) {
if(array[j] != a) {
k++;
}
}
if(k == (i+1)){
array[i] = a;
}

else {
--i;
k = 0;
}

}

for (i = 0; i < 99; i++) {
if(i%20 == 0)
System.out.println();
System.out.print(array[i] + " ");

}
}
}


k的值应该要回0,否则的话,到后面,k的值永远比i大,那么就陷入死循环了
canoe982 2010-03-22
  • 打赏
  • 举报
回复
1楼的代码确实好多了,不过效率很低,总循环次数可能会很大。
可以采取洗牌方式进行处理。
stu202060510 2010-03-22
  • 打赏
  • 举报
回复
public class PanDuan {
public static void main(String args[]) {
int array[] = new int[99];
boolean flag; //用于判断是否发现相同的数

for (int i = 0; i < 99; i++) {
flag=false;
int a = (int) (100 * Math.random());
for (int j = 0; j < i; j++) {
if(array[j]==a){
flag=true;
break;
}
}
if(!flag){
array[i]=a;
}else{
i--;
}
}

for (int i = 0; i < 99; i++) {
System.out.println(array[i]);
}
}
}

你的代码好像是死循环,帮你改了一下。。。。。。。。。。

62,615

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧