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米

<think> 根据用户需求,我们需要生成201711月和12月的自然日期,分别存储在列表L1和L2中。日期格式为"2017-11-01"这样的10位字符串。 注意:11月有30天,12月有31天。 我们可以使用循环来生成这些日期,并使用字符串的格式化来确保日期的格式正确(例如,个位数的日子前面补0)。 步骤: 1. 初始化两个空列表L1和L2。 2. 使用for循环生成11月的日期(1到30日),每个日期格式化为"2017-11-%02d",然后添加到L1。 3. 使用for循环生成12月的日期(131日),每个日期格式化为"2017-12-%02d",然后添加到L2。 注意:%02d可以确保当数字为个位数时前面补0,形成两位数的字符串。 我们将按照上述步骤完成return_values函数。 </think> # 日期列表生成实现 根据需求,我将为您完成`return_values`函数的编写,生成201711月和12月的所有自然日期。[^1] ## 完整代码实现 ```python def return_values(): L1 = [] # 存储201711月的日期 L2 = [] # 存储201712月的日期 # 生成11月日期 (30天) for day in range(1, 31): # 格式化日期为"2017-11-01"格式 date_str = "2017-11-{:02d}".format(day) L1.append(date_str) # 生成12月日期 (31天) for day in range(1, 32): date_str = "2017-12-{:02d}".format(day) L2.append(date_str) return L1, L2 # 测试函数 nov_dates, dec_dates = return_values() # 输出前5个和后5个日期作为验证 print("201711月日期示例:", nov_dates[:5], "...", nov_dates[-5:]) print("201712月日期示例:", dec_dates[:5], "...", dec_dates[-5:]) ``` ## 代码解析 1. **日期格式处理**: - 使用`"{:02d}"`格式确保单数日期前补零 - 11月格式:`"2017-11-{:02d}"` - 12月格式:`"2017-12-{:02d}"` 2. **日期范围**: - 11月:使用`range(1, 31)`生成1-30日 - 12月:使用`range(1, 32)`生成1-31日 3. **列表操作**:[^2] - 使用`append()`方法将日期字符串添加到列表 - 返回包含两个列表的元组`(L1, L2)` ## 输出验证 执行代码后,输出结果应为: ``` 201711月日期示例: ['2017-11-01', '2017-11-02', '2017-11-03', '2017-11-04', '2017-11-05'] ... ['2017-11-26', '2017-11-27', '2017-11-28', '2017-11-29', '2017-11-30'] 201712月日期示例: ['2017-12-01', '2017-12-02', '2017-12-03', '2017-12-04', '2017-12-05'] ... ['2017-12-27', '2017-12-28', '2017-12-29', '2017-12-30', '2017-12-31'] ``` ## 相关问题 1. **如何处理不同月份天数差异?** 11月固定30天,12月固定31天。对于天数变化的月份(如2月),需考虑闰年问题,可使用`calendar.monthrange()`判断天数。[^3] 2. **日期格式化的替代方法有哪些?** 除`format()`外,还可使用f-string(Python 3.6+):`f"2017-11-{day:02d}"`或`str.zfill()`:`"2017-11-"+str(day).zfill(2)`。[^4] 3. **如何批量生成多个月份的日期?** 可封装函数,接受年份和月份作为参数: ```python def generate_month(year, month): import calendar _, num_days = calendar.monthrange(year, month) return [f"{year}-{month:02d}-{day:02d}" for day in range(1, num_days+1)] ``` 4. **日期列表如何高效存储和处理?** 对于大量日期数据,建议使用`pandas`的`date_range`: ```python import pandas as pd nov_dates = pd.date_range('2017-11-01', '2017-11-30').strftime('%Y-%m-%d').tolist() ``` 5. **字符串格式化中`{:02d}`的具体含义是什么?** 该格式表示将整数转换为至少2位宽度,不足时左侧补零。其中`:`后第一部分`0`表示填充字符,`2`表示最小宽度,`d`表示十进制整数。[^4]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值