Java学习连载001
发布日期:2021-06-29 07:20:12
浏览次数:2
分类:技术文章
本文共 11778 字,大约阅读时间需要 39 分钟。
第四天:程序逻辑-2(分支和循环)
练习1:猜数字
计算机出一个1-100之间的随机数,玩家输入猜测的数字,计算机会给出相应的提示:如果玩家猜测的数字大于计算机出的数字,则提示"小一点";如果玩家猜测的数字小于计算机出的数字,则提示"大一点";如果猜对了就给出恭喜信息和猜的次数,游戏结束。package com.lovoinfo;import java.util.Scanner;/** * 猜数字 * @author jackfrued * */public class Test04 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int correctAnswer = (int) (Math.random() * 100 + 1); int counter = 0; int thyAnswer; do { System.out.print("请输入你猜的数字: "); thyAnswer = sc.nextInt(); counter += 1; if (thyAnswer == correctAnswer) { System.out.println("恭喜你猜对了!总共猜了" + counter + "次"); if(counter > 7) { System.out.println("智商拙计!!!"); } } else if (thyAnswer > correctAnswer) { System.out.println("小一点!"); } else { System.out.println("大一点"); } } while (thyAnswer != correctAnswer); sc.close(); }}
练习2:人机猜拳
package com.lovoinfo;import java.util.Scanner;/** * 人机猜拳 * @author jackfrued * */public class Test05 { /** * 将出拳对应的数字变成中文 * @param fist 出拳的数字 * @return 出拳字对应的中文 */ public static String getFist(int fist) { String str; if(fist == 1) { str = "剪刀"; } else if(fist == 2) { str = "石头"; } else { str = "布"; } return str; } public static void main(String[] args) { Scanner sc = new Scanner(System.in); int money = 1000; do { int debt; do { System.out.println("你总共有" + money + "元"); System.out.print("请下注: "); debt = sc.nextInt(); } while(debt <= 0 || debt > money); int computerFist = (int) (Math.random() * 3 + 1); int thyFist; do { System.out.print("请出拳(1. 剪刀; 2. 石头; 3. 布): "); thyFist = sc.nextInt(); } while (thyFist < 1 || thyFist > 3); System.out.println("计算机出的是" + getFist(computerFist)); System.out.println("你出的是" + getFist(thyFist)); if(computerFist == thyFist) { System.out.println("平局!"); } else { if(computerFist == 1) { if(thyFist == 2) { money += debt; System.out.println("你赢了!"); } else { money -= debt; System.out.println("计算机赢了!"); } } else if(computerFist == 2) { if(thyFist == 1) { money -= debt; System.out.println("计算机赢了!"); } else { money += debt; System.out.println("你赢了!"); } } else { if(thyFist == 1) { money += debt; System.out.println("你赢了!"); } else { money -= debt; System.out.println("计算机赢了!"); } } } } while(money > 0); System.out.println("你破产了!游戏结束!"); sc.close(); }}
练习3:Craps赌博游戏。
玩家摇两颗色子,如果第一次摇出了7点和11点,则玩家胜;如果第一次摇出了2点、3点、12点,则庄家胜;如果摇出其他点数,游戏继续,在继续的过程中,如果玩家摇出了第一次摇的点数,则玩家胜;如果摇出了7点,则庄家胜;否则游戏继续,直到分出胜负。package com.lovoinfo;import java.util.Scanner;/** * Craps赌博游戏 * @author jackfrued * */public class Test03 { /** * 摇两颗色子 * @return 两个色子摇出的点数之和 */ public static int rollDice() { int face1 = (int) (Math.random() * 6 + 1); int face2 = (int) (Math.random() * 6 + 1); return face1 + face2; } public static void main(String[] args) { Scanner sc = new Scanner(System.in); int money = 1000; do { int debt = 0; // 下注的金额 do { System.out.println("你的余额" + money + "元"); System.out.print("请下注: "); if(sc.hasNextInt()) { // 判断能否读到一个整数 debt = sc.nextInt(); } else { System.out.println("输入错误!"); sc.nextLine(); // 把错误的输入读走 } } while (debt <= 0 || debt > money); int firstPoint = rollDice(); System.out.println("玩家摇出了" + firstPoint + "点"); boolean gameOver = true; // 表示游戏是否应该结束的布尔值 switch(firstPoint) { case 7: case 11: money += debt; System.out.println("玩家胜!"); break; case 2: case 3: case 12: money -= debt; System.out.println("庄家胜!"); break; default: gameOver = false; // 如果第一次没有分出胜负游戏就没有结束 } while(!gameOver) { // 只要游戏没有结束就要继续摇色子 int currentPoint = rollDice(); System.out.println("玩家摇出了" + currentPoint + "点"); if(currentPoint == 7) { money -= debt; System.out.println("庄家胜!"); gameOver = true; } else if(currentPoint == firstPoint) { money += debt; System.out.println("玩家胜!"); gameOver = true; } } } while(money > 0); System.out.println("恭喜你, 破产了!"); sc.close(); }}
练习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:百钱百鸡。
公鸡5元一只,母鸡3元一只,小鸡1元三只,用100元买100只鸡,问公鸡、母鸡和小鸡各有多少只?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); } } } }}###第五天:数组、方法和字符串###1. 一维数组定义数组的语法:
T[] x = new T[size];
T[] y = { value1, value2, … };- 操作数组元素可以使用下标运算[ ],数组的下标范围0-(数组大小-1)。- 数组有一个length属性表示数组元素的个数。- 通常可以用循环来对数组中的元素进行操作。练习1:录入5名学生的成绩,计算平均分,找出最高分和最低分。```Javapackage com.lovoinfo;import java.util.Scanner;public class Test01 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String[] names = { "关羽", "张飞", "赵云", "黄忠", "马超"}; double[] scores = new double[5]; double sum = 0; for(int i = 0; i < scores.length; i++) { System.out.print("请输入" + names[i] + "的成绩: "); scores[i] = sc.nextDouble(); sum = sum + scores[i]; } System.out.println("平均分为: " + sum / scores.length); int maxIndex = 0, minIndex = 0; for(int i = 1; i < scores.length; i++) { if(scores[i] > scores[maxIndex]) { maxIndex = i; } else if(scores[i] < scores[minIndex]) { minIndex = i; } } System.out.println(names[maxIndex] + "考了最高分" + scores[maxIndex]); System.out.println(names[minIndex] + "考了最低分" + scores[minIndex]); sc.close(); }}
练习2:输出前20个Fibonacci数。
1, 1, 2, 3, 5, 8, 13, 21, 34, …package com.lovoinfo;/** * 输出前20个Fibonacci数 * @author jackfrued * */public class Test04 { public static void main(String[] args) { int[] f = new int[20]; f[0] = f[1] = 1; for(int i = 2; i < f.length; i++) { f[i] = f[i - 1] + f[i - 2]; } for(int x : f) { System.out.println(x); } }}
练习3:随机产生10个数,并对其进行排序。
package com.lovoinfo;public class Test05 { public static void main(String[] args) { int[] a = new int[10]; System.out.println("排序前: "); for (int i = 0; i < a.length; i++) { a[i] = (int) (Math.random() * 100); System.out.print(a[i] + "\t"); } bubbleSort(a); System.out.println("\n排序后: "); for (int x : a) { System.out.print(x + "\t"); } } /** * 冒泡排序 * @param a 待排序的数组 */ public static void bubbleSort(int[] a) { // N个元素排序需要N-1趟循环 for (int i = 0; i < a.length - 1; i++) { // 相邻元素两两比较 for(int j = 0; j < a.length - 1 - i; j++) { if(a[j] > a[j + 1]) { // 如果前面元素大于后面元素就交换 int temp = a[j]; a[j] = a[j + 1]; a[j + 1] = temp; } } } } /** * 简单选择排序 * @param a 待排序的数组 */ public static void selectionSort(int[] a) { for (int i = 0; i < a.length - 1; i++) { int minIndex = i; // 假设当前的i是最小元素所在的位置 for (int j = i + 1; j < a.length; j++) { if (a[j] < a[minIndex]) { // 发现更小的元素 minIndex = j; // 记录更小的元素所在的位置 } } // 将i位置上的元素和最小元素交换位置 int temp = a[i]; a[i] = a[minIndex]; a[minIndex] = temp; } }}
- 二维数组
练习4:输入5个学生三门课的成绩,计算每个学生的平均分以及每门课程的平均分。
package com.lovoinfo;import java.util.Scanner;public class Test07 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String[] stuNames = { "关羽", "张飞", "赵云", "黄忠", "马超"}; String[] subNames = { "语文", "数学", "英语"}; int[][] scores = new int[stuNames.length][subNames.length]; for(int i = 0; i < scores.length; i++) { System.out.println("请录入" + stuNames[i] + "的成绩"); for(int j = 0; j < scores[i].length; j++) { System.out.print("\t" + subNames[j] + ": "); scores[i][j] = sc.nextInt(); } } // 后面的代码自行完成 sc.close(); }}
练习5:输出10行杨辉三角。
package com.lovoinfo;/** * 杨辉三角 * @author jackfrued * */public class Test08 { public static void main(String[] args) { int[][] y = new int[10][]; for(int i = 0; i < y.length; i++) { y[i] = new int[i + 1]; for(int j = 0; j < y[i].length; j++) { if(j == 0 || j == i) { y[i][j] = 1; } else { y[i][j] = y[i - 1][j] + y[i - 1][j - 1]; } } } for(int[] a : y) { for(int b : a) { System.out.print(b + "\t"); } System.out.println(); } }}
转载地址:https://blog.csdn.net/zkd12344/article/details/45341865 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
感谢大佬
[***.8.128.20]2024年04月17日 23时11分57秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Android四大组件——ContentProvider的增删改查和优化
2019-04-29
华为入局 VR 眼镜能让 VR 早普及几年?|CSDN博文精选
2019-04-29
做好以下四点,拒做 “ 空心 ” 程序员 | CSDN 博文精选
2019-04-29
Java设计模式之状态模式
2019-04-29
C语言atol()函数:将字符串转换成long(长整型)
2019-04-29
C语言atof()函数:将字符串转换为double(双精度浮点数)
2019-04-29
jsp中标签意思
2019-04-29
煤球数目
2019-04-29
如何避免成为一个低级的码农?
2019-04-29
程序员的你一定要记住:你所说的每一句话都会被传出!
2019-04-29
一线 IT 公司开发转管理,我是怎么从 0 到 1 的?
2019-04-29
四平方和
2019-04-29
交换瓶子
2019-04-29
报纸页数
2019-04-29
打印方格
2019-04-29
冰雹数
2019-04-29
网友年龄
2019-04-29
今天百度终于收录了主页-开心-记录一下
2019-04-29
C#实现一直疯狂get访问一个网站
2019-04-29
阿里大牛分享程序员5年的职业生涯指南
2019-04-29