1 猜数字(10次机会)
随机生成[1,1000]的一个数,输入你猜的数程序会给出反馈,直到猜对或次数用尽(10次)。
//猜数字 10次机会
@Test
public void guessNumber() {
Random random = new Random();
// [0, 1000) + 1
// [1, 1000]
int num = random.nextInt(1000) + 1;
Scanner scanner = new Scanner(System.in);
int cnt = 10;
int num_guess;
while (cnt > 0) {
System.out.println("猜吧!请输入你猜的数字: ");
num_guess = scanner.nextInt();
System.out.println("你猜的数字是: " + num_guess);
if (num_guess > num) {
System.out.println("太大了");
cnt--;
} else if(num_guess < num) {
System.out.println("太小了");
cnt--;
} else {
System.out.println("恭喜你,猜对了");
break;
}
}
if (cnt == 0) {
System.out.println("次数用尽,猜数失败");
}
}
2 打印99乘法表(双重循环)
双重for循环:
外层循环控制行数,数一下有几行就能确定外层循环。
内层循环控制列数,这一行打印多少个,到底要打印多少个要找出和当前行之间的一个关系。
//打印99乘法表
@Test
public void print99Table() {
for (int i = 1; i <= 9; i++) {
for (int j = 1; j <= i; j++) {
System.out.print(j + "×" + i + "=" + (i * j));
if(j != i) {
System.out.print(" ");
}
}
System.out.println();
}
}
做这个时候死去的上机题突然攻击我,控制了下每行最后一个空格不输出
3 判断闰年
也有收获,之前写的时候逻辑有一点点混乱,这次搞清楚本身其实可以拆成两个条件:
①能被4整除但不能被100整除
②能被400整除
有点数学容斥原理那味儿(死去的高中数学)
@Test
public void judgeLeapYear() {
System.out.println("请输入你要查询的年份: ");
Scanner scanner = new Scanner(System.in);
int year_in = scanner.nextInt();
if ((year_in % 4 == 0 && year_in % 100 != 0) || (year_in % 400 == 0)) {
System.out.println(year_in + "年是闰年");
return true;
} else {
System.out.println(year_in + "年不是闰年");
return false;
}
}
4 交换数字
老生常谈了
@Test
public void exchangeNumber() {
Scanner scanner = new Scanner(System.in);
System.out.println("请输入第一个数: ");
int num1 = scanner.nextInt();
System.out.println("请输入第二个数: ");
int num2 = scanner.nextInt();
System.out.println("交换前: num1 = " + num1 + "\t" + "num2 = " + num2);
int temp = num1;
num1 = num2;
num2 = temp;
System.out.println("交换后: num1 = " + num1 + "\t" + "num2 = " + num2);
}
嗯,老师还提了一嘴可以有很多方法,我确实只知道这一种。随便一搜确实有很多种
链接1
链接2
5 收银台
编写一个收银台收款程序:
定义输入----单价、数量、用户输入金额
定义输出----应收金额、找零
使用double类型变量 scanner.nextDouble();
当总价>=500时候打八折
考虑程序出现异常的情况,如:收款金额小于应收金额
若收款金额大于等于应收金额,则计算找零后输出
若收款金额小于应收金额,输出错误信息。
这个我写得还挺“长”的,主要是有些信息执行完在控制台不显示,我又加了打印
//收银台
@Test
public void recvMoney() {
int cnt;
double price, total, payment, change;
Scanner scanner = new Scanner(System.in);
System.out.print("请输入商品单价: ");
price = scanner.nextDouble();
System.out.println(price);
System.out.print("请输入商品数量: ");
cnt = scanner.nextInt();
System.out.println(cnt);
System.out.print("请付款: ");
payment = scanner.nextDouble();
System.out.println(payment);
total = price * cnt;
if (total >= 500) {
System.out.println("商品总价超过500元, 给您打八折!");
total *= 0.8;
}
if (payment < total) {
System.out.println("对不起, 您的钱不够");
} else {
change = payment - total;
System.out.println("找您" + String.format("%.2f", change));
}
}
6 打印直角三角形
输出以下结构:
1
12
123
1234
12345
//输出直角三角形数
@Test
public void printRightTriangle() {
for (int i = 1; i <= 5; i++) {
for (int j = 1; j <= i; j++) {
System.out.print(j);
}
System.out.println();
}
}
7 打印正三角形/倒三角形
public void printEquilateralTriangle(int n) {
int m;
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= n - i; j++) {
System.out.print(' ');
}
m = 2 * (i - 1) + 1;
for (int j = 1; j <= m; j++) {
System.out.print('*');
}
System.out.println();
}
}
public void printInvertedTriangle(int n) {
int m;
for (int i = n; i >= 1; i--) {
for (int j = 1; j <= n - i; j++) {
System.out.print(' ');
}
m = 2 * (i - 1) + 1;
for (int j = 1; j <= m; j++) {
System.out.print('*');
}
System.out.println();
}
}
//打印正三角/倒三角形
@Test
public void printTriangle() {
Scanner scanner = new Scanner(System.in);
System.out.print("请输入三角形阶数: ");
int num = scanner.nextInt();
System.out.println(num);
System.out.print("请输入你要打印的三角形类型(1 正三角形; 2 倒三角形): ");
int flag = scanner.nextInt();
System.out.println(flag);
int n = num;
int m;
if (flag == 1) {
printEquilateralTriangle(n);
} else if (flag == 2) {
printInvertedTriangle(n);
} else {
System.out.println("非法输入 ");
}
}
分开写了两个方法然后调用,这样比较舒服
8 求奇数偶数和
计算1-100以内所有奇数的和以及所有偶数的和,分别打印出来
@Test
public void printSum() {
int sum_odd = 0;
int sum_even = 0;
for (int i = 1; i <= 100; i++) {
if(i % 2 == 1) {
sum_odd += i;
}else {
sum_even += i;
}
}
System.out.println("sum_odd = " + sum_odd);
System.out.println("sum_even = " + sum_even);
}
9 输出数字
用for循环输出1—1000之间能被5整除的数,且每行输出3个
@Test
public void printModFive() {
int cnt = 0;
for (int i = 1; i <= 1000; i++) {
if(i % 5 == 0) {
System.out.print(i);
cnt++;
if(cnt % 3 != 0) {
System.out.print(' ');
}
else {
cnt = 0;
System.out.println();
}
}
}
}
10 计算阶乘
计算9的阶乘
@Test
public void printFactorial() {
int ans = 1;
for(int i = 1; i <= 9; i++) {
ans *= i;
}
System.out.println(ans);
}
老师说还能用别的方法,我想到的是大数阶乘,那年暑假集训一道大数阶乘我做了一个晚自习。。。。
大数阶乘1
大数阶乘2
其实他想说的是递归啦,那其实没啥本质区别了,能做的数还是有限的,不过确实算个进阶写法。
后边再补吧,这周要叫开题报告、文献综述和外文翻译。想想就难受