赞
踩
随机生成[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("次数用尽,猜数失败"); } }
双重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();
}
}
做这个时候死去的上机题突然攻击我,控制了下每行最后一个空格不输出
也有收获,之前写的时候逻辑有一点点混乱,这次搞清楚本身其实可以拆成两个条件:
①能被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;
}
}
老生常谈了
@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
编写一个收银台收款程序:
定义输入----单价、数量、用户输入金额
定义输出----应收金额、找零
使用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)); } }
输出以下结构:
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();
}
}
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("非法输入 "); } }
分开写了两个方法然后调用,这样比较舒服
计算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);
}
用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(); } } } }
计算9的阶乘
@Test
public void printFactorial() {
int ans = 1;
for(int i = 1; i <= 9; i++) {
ans *= i;
}
System.out.println(ans);
}
老师说还能用别的方法,我想到的是大数阶乘,那年暑假集训一道大数阶乘我做了一个晚自习。。。。
大数阶乘1
大数阶乘2
其实他想说的是递归啦,那其实没啥本质区别了,能做的数还是有限的,不过确实算个进阶写法。
后边再补吧,这周要叫开题报告、文献综述和外文翻译。想想就难受
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。