练习
1. (for 循环)计算1+2+3+...+100 的和
int a = 0;
for (int i = 1; i <= 100; i++) {
a=a+i;
}
System.out.println(a);
2. (for 循环)计算1+3+5+...+99 的和
int a =0;
for (int i = 1; i <= 99; i++) {
if (i%2==1){
a=a+i;
}
}
System.out.println(a);
3. (while/do…while 循环)把1、2 两题用while 循环或do...while 循环改
写
4. (for 循环)读入一个小于10 的整数n,输出它的阶乘n!
Scanner sc = new Scanner(System.in);
System.out.println("输入数");
int a = sc.nextInt();
sc.close();
int c =1;
if (a<=10) {
for (int i = 1; i <= a; i++) {
c=c*i;
}
System.out.println(c);
}else {
System.out.println("请输入10以内的数");
}
5. (for 循环)求100 以内所有能被3 整除但不能被5 整除的数字的和。
int a =0;
for (int i = 0; i <= 100; i++) {
if (i%3==0&&i%5!=0){
System.out.println(i);
a = a+i;
}
}
System.out.println(a);
6. (for 循环)* “百钱买百鸡”是我国古代的著名数学题。题目这样描述:3 文
钱可以买1只公鸡,2 文钱可以买一只母鸡,1 文钱可以买3 只小鸡。用100 文
钱买100 只鸡,那么各有公鸡、母鸡、小鸡多少只?
for (int i = 0; i<=33; i++) {
for (int j = 0; j <=50; j++) {
if ((100 - i - j) % 3 == 0 && 3 * i + 2 * j + (100 - i - j) / 3 == 100) {
System.out.print("公鸡"+i);
System.out.print("母鸡"+j);
System.out.print("小鸡"+(100-i-j));
System.out.println();
}
}
}
7. (for 循环)*搬砖问题:36 块砖,36 人搬,男搬4,女搬3,两个小孩抬1 砖,
要求一次全搬完,问男、女和小孩各若干?
for (int i = 0; i <= 9; i++) {
for (int j = 0; j <=12 ; j++) {
if ((36-i-j)%2==0&&4*i+3*j+(36-i-j)/2==36){
System.out.print("男"+i);
System.out.print("女"+j);
System.out.print("小孩"+(36-i-j));
System.out.println();
}
}
}
8. (for 循环)*编程找出四位整数abcd 中满足下述关系的数。
(ab+cd)(ab+cd)=abcd
for (int i = 1; i <=9; i++) {
for (int j = 0; j <=9 ; j++) {
for (int k = 0; k <=9 ; k++) {
for (int l = 0; l <=9 ; l++) {
if (((i*10+j)+(k*10+l))*((i*10+j)+(k*10+l))==i*1000+j*100+k*10+l){
System.out.println("i:" +i+"j:"+j+"k:"+k+"l:"+l);
}
}
}
}
}
9. (循环)*读入一个整数n,输出如下图形
n = 3
*
***
*****
n = 4
*
***
*****
*******
思路:读入的整数n,就是外层循环的循环次数。
对于每一行,要做的事情:1. 输出若干个空格;2. 输出若干个星;3. 换行。
提示:输出不换行,用System.out.print()
Scanner sc = new Scanner(System.in);
System.out.println("输入几层");
int a = sc.nextInt();
for (int i = 0; i<=a; i++) {
for (int j = 0; j < i; j++) {
System.out.print("* ");
}
System.out.println();
for (int j=a; j>i;j--) {
System.out.print("-");
}
}
10. (循环)*输出99 乘法表
Scanner sc = new Scanner(System.in);
System.out.println("输入数");
int a = sc.nextInt();
sc.close();
if (a<10) {
for (int i = 1; i <= a; i++) {
for (int j = 1; j <= i; j++) {
System.out.print(j+"*"+i+"="+(j*i)+" ");
}
System.out.println("\n");
}
}else {
System.out.println("请输入10以内的数");
}
11. (循环)**求水仙花数。所谓水仙花数,是指一个三位数abc,如果满足
a3+b3+c3=abc,则abc 是水仙花数。
for (int i = 0; i <= 9; i++) {
for (int j = 0; j <=9; j++) {
for (int k = 0; k <=9; k++) {
if ((i*i*i)+(j*j*j)+(k*k*k)==i*100+j*10+k){
System.out.println(i*100+j*10+k+"是水仙花数");
}
}
}
}
12. (循环)**输入一个整数,计算它各位上数字的和。(注意:是任意位的整数)
Scanner sc = new Scanner(System.in);
System.out.println("输入整数");
int a = sc.nextInt();
int sum = 0;
while (a !=0){
sum += a%10;
a /=10;
}
System.out.println(sum);
13. (循环)**输入一整数A,判断它是否质数。
提示1:若从2 到A 的平方根的范围内,没有一个数能整除A,则A 是质数。
Scanner sc = new Scanner(System.in);
System.out.println("输入数");
int a = sc.nextInt();
boolean b = true;
for (int i = 2; i <= a-1; i++) {
if (a%i==0){
b = false;
break;
}
}
if (b){
System.out.println("是质数");
}else {
System.out.println("不是质数");
}
14. (循环)**如果一个数等于其所有因子之和,我们就称这个数为"完数",例如 6 的因子为1,2,3 6=1+2+3 6 就是一个完数.请编程打印出1000 以内所有的完数
for (int i = 0; i < 1000; i++) {
int sum =0;
for (int j = 1; j < i / 2; j++) {
if (i%j==0){
sum +=j;
}
}
if (sum==i){
System.out.println(sum);
}
}
16. (循环)**已知:faibonacci (费波那契)数列的前几个数分别为0,1,1,2,3,5,……。从第3 项开始,每一项都等于前两项的和。
读入一个整数n,编程求出此数列的前n 项。
注意:这里的数列是从0 开始的。
Scanner sc = new Scanner(System.in);
System.out.println("输入数");
int n = sc.nextInt();
System.out.println(allFai(n));
sc.close();
}
//写一个递归函数,第 n 项的值
public static int fai(int n){
if(n == 1)
return 0;
if(n == 2)
return 1;
return fai(n - 1) + fai(n - 2);
}
//写一个递归函数,前 n 项的和
public static int allFai(int n){
if(n < 1)
return -1;
if(n == 1)
return 0;
if(n == 2)
return 1;
return allFai(fai(n--)) + allFai(fai(n - 1));
}
}