小白Leetcode之路 22/09/23

继续吧,从小白开始蜕变。

题目1:斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:

F(0) = 0,F(1) = 1
F(n) = F(n - 1) + F(n - 2),其中 n > 1
给定 n ,请计算 F(n) 。

示例 1:

输入:n = 2
输出:1
解释:F(2) = F(1) + F(0) = 1 + 0 = 1
示例 2:

输入:n = 3
输出:2
解释:F(3) = F(2) + F(1) = 1 + 1 = 2
示例 3:

输入:n = 4
输出:3
解释:F(4) = F(3) + F(2) = 2 + 1 = 3
 

提示:

0 <= n <= 30

很经典的斐波拉契数列问题,之前在数据结构那本书上也接触过这样的数列,记得是用递归实现的,所以这里直接使用了递归进行解题。

class Solution {

public:

    int fib(int n) {

        if(n<2) return n;

        

        else return fib(n-1)+fib(n-2);

    }

};

但是很明显此次提交时间复杂度与空间复杂度都偏高,并不是最优解,原因如下:

 可以看到对于F(6)来说 那些颜色相同的如F(2)、F(3)来说都是重复计算的,所以对于n值来说,越大重复的计算就越多,所以能不能设置类似一个cache的缓冲池,将已经计算过的值放在这个缓冲池里面,每当我们遇到一个新的数需要递归计算,通过查看这个缓冲池看看之前是否计算过,将数直接取出,节省重复计算的时间。

因此可以优化,其实这就涉及到动态规划中的一点:记忆式搜索。

class Solution {
public:
    int notebook[31] = {0};
    int fib(int n) {
        if (n == 0) {
            return 0;
        } else if (n == 1) {
            return 1;
        } else {
            if (notebook[n] != 0) {
                return notebook[n];
            } else {
                notebook[n] = fib(n - 1) + fib(n - 2);
                return notebook[n];
            }
        }
    }
};

题目2 这次抽到了一道数据库的题,还好题目简单,成功ac。

活动表 Activity:

+--------------+---------+
| Column Name  | Type    |
+--------------+---------+
| player_id    | int     |
| device_id    | int     |
| event_date   | date    |
| games_played | int     |
+--------------+---------+
表的主键是 (player_id, event_date)。
这张表展示了一些游戏玩家在游戏平台上的行为活动。
每行数据记录了一名玩家在退出平台之前,当天使用同一台设备登录平台后打开的游戏的数目(可能是 0 个)。
 

写一条 SQL 查询语句获取每位玩家 第一次登陆平台的日期。

查询结果的格式如下所示:

Activity 表:
+-----------+-----------+------------+--------------+
| player_id | device_id | event_date | games_played |
+-----------+-----------+------------+--------------+
| 1         | 2         | 2016-03-01 | 5            |
| 1         | 2         | 2016-05-02 | 6            |
| 2         | 3         | 2017-06-25 | 1            |
| 3         | 1         | 2016-03-02 | 0            |
| 3         | 4         | 2018-07-03 | 5            |
+-----------+-----------+------------+--------------+

Result 表:
+-----------+-------------+
| player_id | first_login |
+-----------+-------------+
| 1         | 2016-03-01  |
| 2         | 2017-06-25  |
| 3         | 2016-03-02  |
+-----------+-------------+

解题思路:通过查表可知,每位玩家登陆记录不止一次,要想知道每位玩家的第一次登录记录,实际上只要找到该玩家的登陆记录中时间最早的一次即可,通过min函数可以很好解决。同时把这个查询结果起个新名字以示区别。

# Write your MySQL query statement below

select player_id, min(event_date) as first_login

from Activity

group by player_id;

优化:本次答案难得与高赞答案一致,可能是MySQL语句没有太多可以优化的地方吧,本身就是一个查询语句,后续如果发现更好的将会第一时间更新。
 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值