题一:下面两个函数的返回值是一样的吗?为什么?
function foo1()
{
return {
bar: "hello"
};
}
function foo2()
{
return
{
bar: "hello"
};
}
{bar: "hello"}
undefined
JS是一门早熟的语言,一些早期的设计失误没有机会被修复。自动分号插入算法就是其中之一。
总体上,自动分号插入算法还算正常,但是在一些小地方留下了不易发觉的坑。比如return语句。foo1函数return后会自动插入分号,导致完全违背期望的结果。
这一古怪行为往往被解释为在JS中应采用一行内跟随大括号的书写风格(即Java的风格,或者说是K&R的C的原初风格,而不是C#风格),其实追根述源,问题还是出在分号上。不要插分号的地方被插了分号,这挺坑爹了,但更更坑爹的是想要插的结果没插。这就是括号的问题。
更多内容请参考下面链接。
作者:贺师俊 链接:https://www.zhihu.com/question/20298345/answer/14670020
来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
题目二:用一条 SQL 语句,查询出每门课都大于 80 分的学生姓名。
DROP TABLE IF EXISTS t_student_score;
CREATE TABLE t_student_score(
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(10) NOT NULL,
course VARCHAR(10) NOT NULL,
score INT NOT NULL
);
INSERT INTO t_student_score(name,course,score) VALUES('张三','语文',81);
INSERT INTO t_student_score(name,course,score) VALUES('张三','数学',75);
INSERT INTO t_student_score(name,course,score) VALUES('李四','语文',76);
INSERT INTO t_student_score(name,course,score) VALUES('李四','数学',90);
INSERT INTO t_student_score(name,course,score) VALUES('王五','语文',81);
INSERT INTO t_student_score(name,course,score) VALUES('王五','数学',100);
INSERT INTO t_student_score(name,course,score) VALUES('王五','英语',90);
INSERT INTO t_student_score(name,course,score) VALUES('王天','英语',70);
-- 反向思维(推荐)
SELECT DISTINCT ss.name FROM t_student_score AS ss
WHERE name NOT IN (
SELECT s.name
FROM t_student_score AS s
WHERE s.score < 80
);
-- 笛卡尔乘积
SELECT DISTINCT a.name
-- SELECT * #测试代码
FROM t_student_score AS a,t_student_score AS b #笛卡尔乘机
WHERE a.name = b.name #姓名相同 提出重复数据
AND a.id <> b.id #id不同 剔除重复数据
AND a.course <> b.course #课目不同 防止不同学生有补考成绩
AND a.score > 80
AND b.score > 80;
题目三:一球从 100 米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第 10 次落地时,共经过多少米?第 10 次反弹多高?
public class d20171031 {
public static void main(String[] args) {
double h = 100;
double sum = h;
int i;
for ( i = 1; i <= 10; i++) {
h = h/2;
System.out.println("第"+i+"次反弹的高度"+h);
if (i == 10) {
continue;
}
sum += h;
}
System.out.println("落地次数"+(i-1)+"共经过"+sum+"米");
}
}
第1次反弹的高度50.0
第2次反弹的高度25.0
第3次反弹的高度12.5
第4次反弹的高度6.25
第5次反弹的高度3.125
第6次反弹的高度1.5625
第7次反弹的高度0.78125
第8次反弹的高度0.390625
第9次反弹的高度0.1953125
第10次反弹的高度0.09765625
落地次数10共经过199.8046875米