第三天学习
程序逻辑-②(分支和循环)##
练习5:将一颗色子掷60000次,统计每一面出现的次数。
package com.lovoinfo;
public class ThrowDie {
public static void main(String[] args) {
int f1 = 0, f2 = 0, f3 = 0, f4 = 0, f5 = 0, f6 = 0;
for(int i = 1; i <= 60000; i++) {
int face = (int)(Math.random() * 6 + 1);
switch(face) {
case 1: f1++; break;
case 2: f2++; break;
case 3: f3++; break;
case 4: f4++; break;
case 5: f5++; break;
case 6: f6++; break;
}
}
System.out.println("1点出现了" + f1 + "次");
System.out.println("2点出现了" + f2 + "次");
System.out.println("3点出现了" + f3 + "次");
System.out.println("4点出现了" + f4 + "次");
System.out.println("5点出现了" + f5 + "次");
System.out.println("6点出现了" + f6 + "次");
}
}
练习6:编程计算$$$\sum_{n=1}^{100}n$$$。
package com.lovoinfo;
/**
* 用while循环实现1-100求和
* @author jackfrued
*
*/
public class Test03 {
public static void main(String[] args) {
int sum = 0; // 累加变量
int i = 1; // 循环变量
while(i <= 100) {
sum += i++;
}
System.out.println("Sum = " + sum);
}
}
package com.lovoinfo;
/**
* 用do...while循环实现1-100求和
* @author jackfrued
*
*/
public class Test04 {
public static void main(String[] args) {
int sum = 0;
int i = 1;
do {
sum = sum + i;
i = i + 1;
} while(i <= 100);
System.out.println("Sum = " + sum);
}
}
package com.lovoinfo;
/**
* 使用for循环实现1-100求和
* @author jackfrued
*
*/
public class Test05 {
public static void main(String[] args) {
int sum = 0;
for(int i = 1; i <= 100; ++i) {
sum += i;
}
System.out.println("Sum = " + sum);
}
}
作业:计算1-100之间的偶数的和。
public class Test_10 {
public static void main(String[] args) {
int a = 0;
for(int i = 0;i <= 100;i+=2){
a=a+i;
}System.out.println(a);
}
}
练习7:编程计算$$$\sum_{n=1}^{10}\frac1{n}$$$。
package com.lovoinfo;
public class Test06 {
public static void main(String[] args) {
double sum = 0;
for(int i = 1; i <= 10; i++) {
sum = sum + 1.0 / i;
}
System.out.println(sum);
}
}
练习8:编程输入$$$n$$$,计算$$$n!$$$。
提示:$$$n!=n\times(n-1)\times(n-2)\cdots\times2\times1$$$
package com.lovoinfo;
import java.util.Scanner;
public class Test07 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("n = ");
int n = sc.nextInt();
double result = 1;
for(int i = 1; i <= n; ++i) {
result = result * i;
}
System.out.println(n + "! = " + result);
sc.close();
}
}
作业:输入两个正整数m和n,计算mn。
public class Tast {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("m:");
int m = sc.nextInt();
System.out.print("n:");
int n = sc.nextInt();
int y = 1;
for(int i = 1;
i <= n;
++i){
y = y*m;
}
System.out.println(y);
sc.close();
}
}
练习9:找出1-100之间的素数。
package com.lovoinfo;
/**
* 找出1-100之间的素数(质数, 只能被1和自身整除的数)
* @author jackfrued
*
*/
public class Test12 {
public static void main(String[] args) {
for(int i = 1; i <= 100; i++) {
// 假定当前的i是素数将isPrime赋值为true
boolean isPrime = true;
// 在2-(i-1)之间找寻i的因子
for(int j = 2; isPrime && j <= i - 1; j++) {
// i能被j整除说明它不是素数
if(i % j == 0) {
// 将isPrime修改成false表示i不是素数
isPrime = false;
}
}
// 如果isPrime的值是true说明i是素数就打印它
if(isPrime) {
System.out.println(i);
}
}
}
}
练习10:找出1-100之间的完美数。
提示:完美数是该数除自身外的所有因子之和等于这个数本身的数。如28=1+2+4+7+14。
public class Test_8 {
public static void main(String[] args) {
for (int i = 1; i <= 100; i++) {
int sum = 0;
for (int m = 1; m <= i / 2; m++) {
if (i % m == 0) {
sum += m;
}
}
if (sum == i) {
System.out.println(i);
}
}
}
}
练习11:找出100-999之间的水仙花数。
提示:水仙花数是各位立方和等于这个数本身的数,如153=13+53+33。
package com.lovoinfo;
public class Test11 {
public static void main(String[] args) {
for(int i = 100; i <= 999; i++) {
int gw = i % 10;
int sw = i / 10 % 10;
int bw = i / 100;
if(gw * gw * gw + sw * sw * sw + bw * bw * bw == i) {
System.out.println(i);
}
}
// for(int bw = 1; bw <= 9; bw++) {
// for(int sw = 0; sw <= 9; sw++) {
// for(int gw = 0; gw <= 9; gw++) {
// int num = bw * 100 + sw * 10 + gw;
// if(bw * bw * bw + sw * sw * sw + gw * gw * gw == num) {
// System.out.println(num);
// }
// }
// }
// }
}
}
练习12:输入两个正整数,计算最大公约数和最小公倍数。
import java.util.Scanner;
public class Test_7 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("请输入第一个数:");
int a = sc.nextInt();
System.out.println("请输入第二个数:");
int b = sc.nextInt();
int n = 0;
for(int i = 1;;i++){
if(i%a == 0 && i%b == 0){
System.out.println(a+"和"+b+"d的最小公倍数是:"+i);
break;
}
for(int m =1;m <=a || m <=b;m++){
if(a%m==0 && b%m==0){
n=m;
}
}
}System.out.println(a+"和"+b+"的最大公约数是:"+n);
sc.close();
}
}
第四天:程序逻辑-2(分支和循环)###
练习1:猜数字(人猜/机器猜)
练习2:人机猜拳
练习3:Craps赌博游戏
练习4:九九表
package com.lovoinfo;
public class Test09 {
public static void main(String[] args) {
for(int i = 1; i <= 9; i++) {
for(int j = 1; j <= i; j++) {
System.out.printf("%d*%d=%d\t", i, j, i * j);
}
System.out.println();
}
}
}
作业:输出直角三角形图案。
package com.lovoinfo;
public class Test10 {
private static final int ROW = 10;
public static void main(String[] args) {
for(int i = 1; i <= ROW; i++) {
for(int j = 1; j <= i; j++) {
System.out.print("*");
}
System.out.println();
}
System.out.println("\n---华丽的分隔线---\n");
for(int i = 1; i <= ROW; i++) {
for(int j = ROW; j >= i; j--) {
System.out.print("*");
}
System.out.println();
}
System.out.println("\n---华丽的分隔线---\n");
for(int i = 1; i <= ROW; i++) {
for(int j = 1; j <= ROW; j++) {
if((ROW - i) >= j) {
System.out.print(" ");
}
else {
System.out.print("*");
}
}
System.out.println();
}
}
}
练习5:百钱百鸡
package com.lovoinfo;
/**
* 百钱买百鸡(穷举法)
* @author jackfrued
*
*/
public class Test14 {
public static void main(String[] args) {
System.out.println("公鸡\t母鸡\t小鸡");
// 假设公鸡x只, 母鸡y只, 小鸡z只
for(int x = 0; x <= 20; x++) {
for(int y = 0; y <= 33; y++) {
int z = 100 - x - y;
if(5 * x + 3 * y + z / 3 == 100 && z % 3 == 0) {
System.out.printf("%d\t%d\t%d\n", x, y, z);
}
}
}
}
}