1.10 阶段练习题(5题较难。)
1
1.1减肥计划if版本【应用】
1.1.1案例需求
输入星期数,显示今天的减肥活动 周一:跑步 周二:游泳 周三:慢走 周四:动感单车 周五:拳击
周六:爬山 周日:好好吃一顿
*/
/*
思路:
1:键盘录入一个星期数,用一个变量接收
2:对星期数进行判断,这里用 if 语句实现
3:在对应的语句控制中输出对应的减肥活动
package Demo03;
import java. util. Scanner;
public class Demo01 {
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
/*
1.2减肥计划switch版本【应用】
1.2.1案例需求
*/
//键盘录入一个星期数,用一个变量接收
package Demo03;
import java. util. Scanner;
public class Demo02 {
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 ( "你输入的星期数有误" ) ;
}
}
}
3
1.3逢七跳过【应用】
案例需求
朋友聚会的时候可能会玩一个游戏:逢七过。 规则是:
从任意一个数字开始报数,当你要报的数字包含7或者是7的倍数时都要说:过。
为了帮助大家更好的玩这个游戏,这里我们直接在控制台打印出1-100之间的满足
逢七必过规则的数据。
这样,大家将来在玩游戏的时候,就知道哪些数据要说:过。
package Demo03;
public class Demo03 {
public static void main ( String[ ] args) {
for ( int i = 1 ; i <= 100 ; i++ ) {
if ( ( i % 7 == 0 ) || ( i / 10 == 7 ) || ( i % 10 == 7 ) ) {
System. out. println ( i) ;
}
}
}
}
4
1.4不死神兔【应用】
1.4.1案例需求
有一对兔子,从出生后第3个月起每个月都生一对兔子,
小兔子长到第三个月后每个月又生一对兔子,
假如兔子都不死,问第二十个月的兔子对数为多少?
思路:
1:为了存储多个月的兔子对数,定义一个数组,用动态初始化完成数组元素的初始化,长度为20
2:因为第1个月,第2个月兔子的对数是已知的,都是1,所以数组的第1个元素,第2个元素值也都
是1
3:用循环实现计算每个月的兔子对数
4:输出数组中最后一个元素的值,就是第20个月的兔子对数
package Demo03;
public class Demo04 {
public static void main ( String[ ] args) {
int [ ] arr = new int [ 20 ] ;
arr[ 0 ] = 1 ;
arr[ 1 ] = 1 ;
for ( int i = 2 ; i < arr. length; i++ ) {
arr[ i] = arr[ i - 2 ] + arr[ i - 1 ] ;
}
System. out. println ( arr[ 4 ] ) ;
System. out. println ( arr[ 19 ] ) ;
}
}
5
1.5百钱白鸡【应用】
1.5.1案例需求
我国古代数学家张丘建在《算经》一书中提出的数学问题:
鸡翁一值钱五,鸡母一值钱三,鸡雏三值钱一。
百钱买百鸡,问鸡翁、鸡母、鸡雏各几何?
package Demo03;
public class Demo05 {
public static void main ( String[ ] args) {
int a = 5 ;
int b = 3 ;
int c = 1 ;
for ( int x = 0 ; x <= 100 / 5 ; x++ ) {
for ( int y = 0 ; y < 100 / 3 ; y++ ) {
if ( ( ( a * x) + ( b * y) + ( ( 100 - x - y) / 3 * c) == 100 ) && ( ( 100 - x - y) % 3 == 0 ) ) {
System. out. println ( x + " " + y + " " + ( 100 - x - y) ) ;
}
}
}
}
}
6
1.6数组元素求和【应用】
1.6.1案例需求
有这样的一个数组,元素是{68,27,95,88,171,996,51,210}。求出该数组中满足要求的元素和, 要求
是:求和的元素个位和十位都不能是7,并且只能是偶数
package Demo03;
public class Demo06 {
public static void main ( String[ ] args) {
int [ ] arr = { 68 , 27 , 95 , 88 , 171 , 996 , 51 , 210 } ;
sumArr ( arr) ;
}
public static void sumArr ( int [ ] arr) {
int sum = 0 ;
for ( int i : arr) {
if ( ( i % 7 != 7 ) && ( i / 10 != 7 ) ) {
sum += i;
}
}
System. out. println ( sum) ;
}
}
7
/*1.7判断两个数组是否相同【应用】
1.7.1案例需求
定义一个方法,用于比较两个数组的内容是否相同*/
package Demo03;
public class Demo07 {
public static void main ( String[ ] args) {
int [ ] arr1 = { 1 , 2 , 3 , 4 , 5 } ;
int [ ] arr2 = { 1 , 2 , 3 , 4 , 5 } ;
boolean bn = compareDemo ( arr1, arr2) ;
if ( bn) {
System. out. println ( "等" ) ;
} else {
System. out. println ( "不等" ) ;
}
}
public static boolean compareDemo ( int [ ] arr1, int [ ] arr2) {
if ( arr1. length == arr2. length) {
for ( int i = 0 ; i < arr1. length; i++ ) {
if ( arr1[ i] != arr2[ i] ) {
return false ;
}
}
} else {
return false ;
}
return true ;
}
}
8
1.8查找元素在数组中出现的索引位置【应用】
1.8.1案例需求
已知一个数组 arr = {19, 28, 37, 46, 50}; 键盘录入一个数据,查找该数据在数组中的索引。
并在控制台输出找到的索引值。如果没有查找到,则输出-1
package Demo03;
import java. util. Random;
import java. util. Scanner;
public class Demo08 {
public static void main ( String[ ] args) {
int [ ] arr = { 19 , 28 , 37 , 46 , 50 } ;
Scanner sc = new Scanner ( System. in) ;
System. out. println ( "请输入数字" ) ;
int num = sc. nextInt ( ) ;
int i = arrNum ( arr, num) ;
System. out. println ( i) ;
}
public static int arrNum ( int [ ] arr, int num) {
for ( int i = 0 ; i < arr. length; i++ ) {
if ( arr[ i] == num) {
return i;
}
}
return - 1 ;
}
}
9
1.9数组元素反转【应用】
1.9.1案例需求
已知一个数组 arr = {19, 28, 37, 46, 50};
用程序实现把数组中的元素值交换, 交换后的数组 arr = {50,
46, 37, 28, 19}; 并在控制台输出交换后的数组元素。
package Demo03;
public class Demo09 {
public static void main ( String[ ] args) {
int [ ] arr = { 19 , 28 , 37 , 46 , 50 } ;
reverse ( arr) ;
printArray ( arr) ;
}
private 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 ( "]" ) ;
}
private 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;
}
}
}
10
1.10评委打分【应用】
1.10.1案例需求
在编程竞赛中,有6个评委为参赛的选手打分,分数为0-100的整数分。
选手的最后得分为:去掉一个最高分和一个最低分后
的4个评委平均值 (不考虑小数部分)。
package Demo03;
import java. util. Scanner;
public class Demo10 {
public static void main ( String[ ] args) {
Scanner sc = new Scanner ( System. in) ;
int [ ] arr = new int [ 6 ] ;
for ( int i = 0 ; i < 6 ; i++ ) {
System. out. println ( "请输入分数" ) ;
arr[ i] = sc. nextInt ( ) ;
}
int pj = score ( arr) ;
System. out. println ( "平均成绩:" + pj) ;
}
private static int score ( int [ ] arr) {
int max = getMax ( arr) ;
int min = getMin ( arr) ;
int sum = 0 ;
for ( int i : arr) {
sum += i;
}
int pj = ( sum - max - min) / ( arr. length - 2 ) ;
return pj;
}
private static int getMin ( int [ ] arr) {
int max = arr[ 0 ] ;
for ( int i : arr) {
max = max > i ? max : i;
}
return max;
}
private static int getMax ( int [ ] arr) {
int min = arr[ 0 ] ;
for ( int i : arr) {
min = min < i ? min : i;
}
return min;
}
}