iteye_12241 2011-08-28 15:57

# 多重for循环的continue问题

[code="java"]import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Set;

public class Problem60 {

``````public static boolean[] prime = new boolean[1000000];

public static boolean IsPrime(long number) {

for (int i = 2; i * i <= number; i++) {
if (number % i == 0)
return false;
}
return true;
}

public static void main(String[] args){
Arrays.fill(prime, false);
prime[1] = true;
prime[2] = true;
int count_prime = 0;
for(int i=3; i<1000; i=i+2){
if(IsPrime(i)){
prime[i] = true;
count_prime++;
}
}
int[] prime_set = new int[count_prime];
prime_set[0] = 1;
prime_set[1] = 3;
int index = 2;
for(int i=7; i<1000; i++){
if(prime[i])
prime_set[index++] = i;
}

for(int i=3; i<prime.length; i=i+2){
if(IsPrime(i)){
prime[i] = true;
}
}

System.out.println("prime_set:"+prime_set.length);
int len = prime_set.length;
int i=0,j=0,k=0,l=0,m=0;
for(i=0; i<len; i++){
for(j=i+1; j<len; j++){
int t1= Integer.parseInt(prime_set[i]+""+prime_set[j]);
int t2= Integer.parseInt(prime_set[j]+""+prime_set[i]);
if(!prime[t1]||!prime[t2]){
continue;
}
for(k=j+1; k<len; k++){
int t3= Integer.parseInt(prime_set[i]+""+prime_set[k]);
int t4= Integer.parseInt(prime_set[k]+""+prime_set[i]);
int t5= Integer.parseInt(prime_set[k]+""+prime_set[j]);
int t6= Integer.parseInt(prime_set[j]+""+prime_set[k]);
if(!prime[t3]||!prime[t4]||!prime[t5]||!prime[t6]){
continue;
}
for(l=k+1; l<len; l++){
int t7= Integer.parseInt(prime_set[i]+""+prime_set[l]);
int t8= Integer.parseInt(prime_set[l]+""+prime_set[i]);
int t9= Integer.parseInt(prime_set[l]+""+prime_set[j]);
int t10= Integer.parseInt(prime_set[j]+""+prime_set[l]);
int t11= Integer.parseInt(prime_set[k]+""+prime_set[l]);
int t12= Integer.parseInt(prime_set[l]+""+prime_set[k]);
if(!prime[t7]||!prime[t8]||!prime[t9]||!prime[t10]||!prime[t11]||!prime[t12]){
continue;
}
for(m=l+1; m<len; m++){
int t13= Integer.parseInt(prime_set[i]+""+prime_set[m]);
int t14= Integer.parseInt(prime_set[m]+""+prime_set[i]);
int t15= Integer.parseInt(prime_set[m]+""+prime_set[j]);
int t16= Integer.parseInt(prime_set[j]+""+prime_set[m]);
int t17= Integer.parseInt(prime_set[k]+""+prime_set[m]);
int t18= Integer.parseInt(prime_set[m]+""+prime_set[k]);
int t19= Integer.parseInt(prime_set[m]+""+prime_set[l]);
int t20= Integer.parseInt(prime_set[l]+""+prime_set[m]);
//      System.out.println("i:"+prime_set[i]+",j:"+prime_set[j]+",k:"+prime_set[k]+",l:"+prime_set[l]+",m:"+prime_set[m]);
System.out.println("No:i:"+i+",j:"+j+",k:"+k+",l:"+l+",m:"+m);
if(!prime[t13]||!prime[t14]||!prime[t15]||!prime[t16]||!prime[t17]||!prime[t18]||!prime[t19]||!prime[t20]){
``````

// int sum = prime_set[i]+prime_set[j]+prime_set[k]+prime_set[l]+prime_set[m];
// System.out.println("----------i:"+prime_set[i]+",j:"+prime_set[j]+",k:"+prime_set[k]+",l:"+prime_set[l]+",m:"+prime_set[m]+",sum:"+sum);
// System.out.println("--No:i:"+i+",j:"+j+",k:"+k+",l:"+l+",m:"+m);
continue;
}else{
int sum = prime_set[i]+prime_set[j]+prime_set[k]+prime_set[l]+prime_set[m];
System.out.println("----------i:"+prime_set[i]+",j:"+prime_set[j]+",k:"+prime_set[k]+",l:"+prime_set[l]+",m:"+prime_set[m]+",sum:"+sum);

}
}
}
}
}
}
System.out.println("i:"+i+",j:"+j+",k:"+k+",l:"+l+",m:"+m);
}
}
[/code]

No:i:0,j:1,k:2,l:141,m:166
No:i:1,j:2,k:27,l:120,m:121

No:i:7,j:62,k:121,l:142,m:165
No:i:7,j:62,k:121,l:142,m:166
i:167,j:167,k:167,l:167,m:167

• 写回答

#### 3条回答默认 最新

• AngelAndAngel 2011-08-28 16:00
关注

continue的意思就是 中断本次循环，继续下一次循环，举个简单例子更容易理解：

[code="java"]
for(int i=0;i<10;i++){
for(int k=0;k<20;k++){
System.out.println("start");
if(k==5){
continue;
}
System.out.println("end");

}
}
[/code]

这段代码的意思就是：当k=5的时候，中断本次循环，也就是说不会打出end这个字符串，然后继续循环k=6的时候。

本回答被题主选为最佳回答 , 对您是否有帮助呢?
评论

#### 悬赏问题

• ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
• ¥20 关于URL获取的参数，无法执行二选一查询
• ¥15 液位控制，当液位超过高限时常开触点59闭合，直到液位低于低限时，断开
• ¥15 marlin编译错误，如何解决？
• ¥15 有偿四位数，节约算法和扫描算法
• ¥15 VUE项目怎么运行，系统打不开
• ¥50 pointpillars等目标检测算法怎么融合注意力机制
• ¥20 Vs code Mac系统 PHP Debug调试环境配置
• ¥60 大一项目课，微信小程序