1.输出100以内的所有素数
public class Text7 {
public static void main(String[] args) {
for(int i=2;i<100;i++){
boolean isPrime=true;
for(int j=2;j<i;j++){
if(i%j==0){
isPrime=false;
break;
}
}
if(isPrime){
System.out.print(i+" ");
}
}
}
}
在上述代码中,使用了状态变量isPrime,并初始化为true,当判断出一个数不是素数时,isPrime变为false。并且在for循环语句中使用了break语句,break语句是跳出离break最近的那个循环。continue则是不执行后面的语句,开始下一轮循环。
2.输出前50个素数
public class Text8 {
public static void main(String[] args) {
int count = 0;
for(int i=2;count<50;i++){
boolean isPrime=true;
for(int j=2;j<i;j++){
if(i%j==0){
isPrime=false;
break;
}
}
if(isPrime){
System.out.print(i+" ");
count++;
}
}
}
}
本题思路是我们需要定义一个变量count来计数,并且count<50作为外循环的条件。
3.用辗转相除法求最大公约数
import java.util.Scanner;
public class Text9 {
public static void main(String[] args) {
Scanner in=new Scanner(System.in);
int a=in.nextInt();
int b=in.nextInt();
int t;
int A=a,B=b;
while(b!=0){
t=a%b;
a=b;
b=t;
}
System.out.println(A+"和"+B+"的最大公约数为:"+a);
}
}
上述代码有个小技巧,因为在循环体中a和b的值一直在变,所以我们在对a和b操作时先定义两个变量A和B将a,b原始的值保留下来。
4.使用1元,5元,10元凑出30元,输出一种方案即可!
import java.util.Scanner;
public class Text10 {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int N=in.nextInt();
OUT:
for(int one=0;one<=N;one++){
for(int five=0;five<=N/5;five++){
for(int ten=0;ten<=N/10;ten++){
if(one*1+five*5+ten*10==N){
System.out.println(one+"张1元,"+five+"张5元,"+ten+"张10元组成"+N);
break OUT;
}
}
}
}
}
}
上述代码具有三重嵌套循环,在该代码中使用了标号OUT:目的是让break直接跳出OUT后面那个循环,如果不使用标号,则break只会跳出离它最近的那个循环。
总结一下for循环使用的场合,我们一般会在知道循环次数选择使用for循环。