编程素养Day002
JavaScript 编程题
下面两个函数的返回值是一样的吗?为什么?
答:不一样。因为在javaScript中对于return等语句,紧跟着换行,解析器会自动在return后面加" ; ",所以第二个回返回undefined。
MySQL 编程题
用一条 SQL 语句,查询出每门课都大于 80 分的学生姓名。
表名 student_score
SELECT DISTINCT name FROM student_score WHERE name NOT IN (SELECT DISTINCT name FROM student_score WHERE score <= 80)
在表中,可能会包含重复值。关键词 DISTINCT 用于返回唯一不同的值。
or
SELECT name FROM student_score GROUP BY name HAVING MIN(score) > 80
MIN 函数返回一列中的最小值。NULL 值不包括在计算中。
GROUP BY 实际上就是分类汇总。
Java 编程题
一球从 100 米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第 10 次落地时,共经过多少米?第 10 次反弹多高?
public class Singleton {
/**
*
* @param h 距离
* @param n 次数
* @return 第n次反弹的高度
*/
public static double sumBallHeight(double h, int n) {
if(n ==1) {
return h /2;
}else
return sumBallHeight(h / 2,n - 1);
}
public static void main(String[] args) {
System.out.println(sumBallHeight(100,10));
}
}
public class Demo {
public static void sumBallHeight(int initHeight, int times) {
// 落地时经过多少米
double sum = 0;
// 反弹高度
double height = 0;
for (int i = 1; i <= times; i++) {
if (i == 1) {
height = initHeight/2;
sum += initHeight;
} else {
sum = sum + height * 2;
height = height/2;
}
}
System.out.println("第" + times + "次落地时,共经过" + sum + "米");
System.out.println("第" + times + "次反弹" + height + "米");
}
public static void main(String[] args) {
sumBallHeight(100, 10);
}
}
运行结果: