1.Debug模式
1.1什么是Debug模式【理解】
是供程序员使用的程序调试工具,它可以用于查看程序的执行流程,也可以用于追踪程序执行过程来调试程序。
1.2Debug模式操作流程【应用】
如何加断点
- 选择要设置断点的代码行,在行号的区域后面单击鼠标左键即可
如何运行加了断点的程序
看哪里
点哪里
- 点Step Into (F7)这个箭头,也可以直接按F7
如何删除断点
- 如果是多个断点,可以每一个再点击一次。也可以一次性全部删除
2.基础练习
2.1减肥计划if版本【应用】
2.1.1案例需求
输入星期数,显示今天的减肥活动
周一:跑步
周二:游泳
周三:慢走
周四:动感单车
周五:拳击
周六:爬山
周日:好好吃一顿
2.1.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
|
public class Test01 { public static void main(String[] args) { Scanner sc = new Scanner(System.in);
System.out.println("请输入一个星期数:"); int week = sc.nextInt();
if (week < 1 || week > 7) { System.out.println("你输入的星期数有误"); } else if (week == 1) { System.out.println("跑步"); } else if (week == 2) { System.out.println("游泳"); } else if (week == 3) { System.out.println("慢走"); } else if (week == 4) { System.out.println("动感单车"); } else if (week == 5) { System.out.println("拳击"); } else if (week == 6) { System.out.println("爬山"); } else { System.out.println("好好吃一顿"); } } }
|
2.2减肥计划switch版本【应用】
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
|
public class Test02 { public static void main(String[] args) { Scanner sc = new Scanner(System.in);
System.out.println("请输入一个星期数:"); int week = sc.nextInt();
switch (week) { case 1: System.out.println("跑步"); break; case 2: System.out.println("游泳"); break; case 3: System.out.println("慢走"); break; case 4: System.out.println("动感单车"); break; case 5: System.out.println("拳击"); break; case 6: System.out.println("爬山"); break; case 7: System.out.println("好好吃一顿"); break; default: System.out.println("你输入的星期数有误"); } } }
|
2.3逢七跳过【应用】
2.3.1案例需求
朋友聚会的时候可能会玩一个游戏:逢七过。
规则是:从任意一个数字开始报数,当你要报的数字包含7或者是7的倍数时都要说:过。
为了帮助大家更好的玩这个游戏,这里我们直接在控制台打印出1-100之间的满足逢七必过规则的数据。
这样,大家将来在玩游戏的时候,就知道哪些数据要说:过。
2.3.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
|
public class Test03 { public static void main(String[] args) { for(int x=1; x<=100; x++) { if(x%10==7 || x/10%10==7 || x%7==0) { System.out.println(x); } } } }
|
2.4不死神兔【应用】
2.4.1案例需求
有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问第二十个月的兔子对数为多少?
2.4.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
|
public class Test04 { public static void main(String[] args) { int[] arr = new int[20];
arr[0] = 1; arr[1] = 1;
for(int x=2; x<arr.length; x++) { arr[x] = arr[x-2] + arr[x-1]; }
System.out.println("第二十个月兔子的对数是:" + arr[19]); } }
|
2.5百钱白鸡【应用】
2.5.1案例需求
我国古代数学家张丘建在《算经》一书中提出的数学问题:鸡翁一值钱五,鸡母一值钱三,鸡雏三值钱一。百钱买百鸡,问鸡翁、鸡母、鸡雏各几何?
2.5.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
|
public class Test05 { public static void main(String[] args) { for(int x=0; x<=20; x++) { for(int y=0; y<=33; y++) { int z = 100 - x - y;
if(z%3==0 && 5*x+3*y+z/3==100) { System.out.println(x+","+y+","+z); } } } } }
|
结果
1 2 3 4
| 0,25,75 4,18,78 8,11,81 12,4,84
|
2.6数组元素求和【应用】
2.6.1案例需求
有这样的一个数组,元素是{68,27,95,88,171,996,51,210}。求出该数组中满足要求的元素的和。
要求:求和的元素的个位和十位都不能是7,并且只能是偶数
2.6.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
|
public class Test06 { public static void main(String[] args) { int[] arr = {68, 27, 95, 88, 171, 996, 51, 210};
int sum = 0;
for(int x=0; x<arr.length; x++) { if(arr[x]%10!=7 && arr[x]/10%10!=7 && arr[x]%2==0) { sum += arr[x]; } }
System.out.println("sum:" + sum); } }
|
2.7判断两个数组是否相同【应用】
2.7.1案例需求
定义一个方法,用于比较两个数组的内容是否相同(每个位置的元素相同)
2.7.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
|
public class Test07 { public static void main(String[] args) { int[] arr = {11, 22, 33, 44, 55}; int[] arr2 = {11, 22, 33, 44, 5};
boolean flag = compare(arr,arr2); System.out.println(flag); }
public static boolean compare(int[] arr, int[] arr2) { if(arr.length != arr2.length) { return false; }
for(int x=0; x<arr.length; x++) { if(arr[x] != arr2[x]) { return false; } }
return true; } }
|
2.8查找元素在数组中出现的索引位置【应用】
2.8.1案例需求
已知一个数组 arr = {19, 28, 37, 46, 50}; 键盘录入一个数据,查找该数据在数组中的索引。
并在控制台输出找到的索引值。如果没有查找到,则输出-1
2.8.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
|
public class Test08 { public static void main(String[] args) { int[] arr = {19, 28, 37, 46, 50};
Scanner sc = new Scanner(System.in); System.out.println("请输入要查找的数据:"); int number = sc.nextInt();
int index = getIndex(arr, number);
System.out.println("index: " + index); }
public static int getIndex(int[] arr, int number) { int index = -1;
for(int x=0; x<arr.length; x++) { if(arr[x] == number) { index = x; break; } }
return index; } }
|
2.9数组元素反转【应用】
2.9.1案例需求
已知一个数组 arr = {19, 28, 37, 46, 50}; 用程序实现把数组中的元素值交换,交换后的数组 arr = {50, 46, 37, 28, 19}; 并在控制台输出交换后的数组元素。
2.9.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
public class Test09 { public static void main(String[] args) { int[] arr = {19, 28, 37, 46, 50};
reverse(arr);
printArray(arr); }
public static void reverse(int[] arr) { for (int start = 0, end = arr.length - 1; start <= end; start++, end--) { int temp = arr[start]; arr[start] = arr[end]; arr[end] = temp; } }
public static void printArray(int[] arr) { System.out.print("[");
for (int x = 0; x < arr.length; x++) { if (x == arr.length - 1) { System.out.print(arr[x]); } else { System.out.print(arr[x] + ", "); } }
System.out.println("]"); } }
|
2.10评委打分【应用】
2.10.1案例需求
在编程竞赛中,有6个评委为参赛的选手打分,分数为0-100的整数分。
选手的最后得分为:去掉一个最高分和一个最低分后 的4个评委平均值 (不考虑小数部分)。
2.10.2代码实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
|
public class Test10 { public static void main(String[] args) { int[] arr = new int[6];
Scanner sc = new Scanner(System.in);
for(int x=0; x<arr.length; x++) { System.out.println("请输入第" + (x + 1) + "个评委的打分:"); arr[x] = sc.nextInt(); }
int max = getMax(arr);
int min = getMin(arr);
int sum = getSum(arr);
int avg = (sum - max - min) / (arr.length - 2);
System.out.println("选手的最终得分是:" + avg);
}
public static int getSum(int[] arr) { int sum = 0;
for(int x=0; x<arr.length; x++) { sum += arr[x]; }
return sum; }
public static int getMin(int[] arr) { int min = arr[0];
for(int x=1; x<arr.length; x++) { if(arr[x] < min) { min = arr[x]; } }
return min; }
public static int getMax(int[] arr) { int max = arr[0];
for(int x=1; x<arr.length; x++) { if(arr[x] > max) { max = arr[x]; } }
return max; }
public static void printArray(int[] arr) { System.out.print("[");
for (int x = 0; x < arr.length; x++) { if (x == arr.length - 1) { System.out.print(arr[x]); } else { System.out.print(arr[x] + ", "); } }
System.out.println("]"); } }
|