JavaScript 编程题
下面两个函数的返回值是一样的吗?为什么?
function foo1() {
return {
bar: "hello"
};
}
function foo2() {
return
{
bar: "hello"
};
}
在编程语言中,基本都是使用分号(;)将语句分隔开,这可以增加代码的可读性和整洁性。而在 JS 中,如若语句各占独立一行,通常可以省略语句间的分号(;),JS 解析器会根据能否正常编译来决定是否自动填充分号:
var test = 1 + 2;
console.log(test); //3
在上述情况中,为了正确解析代码,就不会自动填充分号了,但是对于 return 、break、continue 等语句,如果后面紧跟换行,解析器一定会自动在后面填充分号(;),所以上面的第二个函数就变成了这样:
function foo2() {
return;
{
bar: "hello"
};
}
所以第二个函数是返回 undefined。
MySQL 编程题
用一条 SQL 语句,查询出每门课都大于 80 分的学生姓名。
表名 student_score
name | course | score |
---|---|---|
张三 | 语文 | 81 |
张三 | 数学 | 75 |
李四 | 语文 | 76 |
李四 | 数学 | 90 |
王五 | 语文 | 81 |
王五 | 数学 | 100 |
王五 | 英语 | 90 |
SELECT DISTINCT name FROM student_score
WHERE name NOT IN (SELECT DISTINCT name FROM student_score WHERE score<=80);
或者
SELECT name FROM student_score GROUP BY name HAVING MIN(score)>80;
GROUP BY子句之后使用Having子句
可应用限定条件进行分组,以便系统仅对满足条件的组返回结果。因此,在GROUP BY子句后面包含了一个HAVING子句。HAVING类似于WHERE(唯一的差别是WHERE过滤行,HAVING过滤组)AVING支持所有WHERE操作符。
例如,查找雇员数超过2个的部门的最高和最低薪水:
- SELECT dept ,MAX(salary) AS MAXIMUM ,MIN(salary) AS MINIMUM
- FROM STAFF
- GROUP BY dept
- HAVING COUNT(*) > 2
- ORDER BY dept
dept MAXIMUM MINIMUM
设计部 2600 2100
销售部 3500 3000
Java 编程题
一球从 100 米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第 10 次落地时,共经过多少米?第 10 次反弹多高?
public static void main(String[] args) {double sum1 = 0, sum2 = 0, hight = 100.0;
for (int i = 0; i < 10; i++)
{
sum1 += hight;
// 显示了一下高度的变化
// System.out.print(hight);
hight = hight / 2;
// System.out.print(" "+hight);
//System.out.println();
if (i < 9)
{
sum2 +=hight;
}
}
System.out.println("第10次落地时,共经过" + (sum1 + sum2) + "米");
System.out.println("第十次反弹高度为" + hight + "米");
}