1.Debug模式
1.1什么是Debug模式
是供程序员使用的程序调试工具,它可以用于查看程序的执行流程,也可以用于追踪程序执行过程来调试程序。
1.2Debug模式操作流程
如何加断点
选择要设置断点的代码行,在行号的区域后面单击鼠标左键即可
如何运行加了断点的程序
在代码区域右键Debug执行
看哪里
看Debugger窗口
看Console窗口
点哪里
点Step Into (F7)这个箭头,也可以直接按F7
如何删除断点
选择要删除的断点,单击鼠标左键即可
如果是多个断点,可以每一个再点击一次。也可以一次性全部删除
2.基础练习
2.1减肥计划if版本
2.1.1案例需求
输入星期数,显示今天的减肥活动 周一:跑步 周二:游泳 周三:慢走 周四:动感单车 周五:拳击 周六:爬山 周日:好好吃一顿
2.1.2代码实现
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版本
2.2.1案例需求
输入星期数,显示今天的减肥活动 周一:跑步 周二:游泳 周三:慢走 周四:动感单车 周五:拳击 周六:爬山 周日:好好吃一顿
2.2.2代码实现
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代码实现
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代码实现
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代码实现
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
);
}
}
}
}
}
2.6数组元素求和
2.6.1案例需求
有这样的一个数组,元素是{68,27,95,88,171,996,51,210}。求出该数组中满足要求的元素和, 要求是:求和的元素个位和十位都不能是7,并且只能是偶数
2.6.2代码实现
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代码实现
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代码实现
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代码实现
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代码实现
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("]");
}
}