2017-10-31

题一:下面两个函数的返回值是一样的吗?为什么?

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米

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值