双非二本实习前的准备day8

2024-03-08 9760阅读

学习目标:

天2-3到简单sql(刷完即止),每天复习代码随想录上的题目2-3道算法(时间充足可以继续),背诵的八股的问题也在这里记录了

双非二本实习前的准备day8 第1张
()

今日碎碎念:

1)今天任务:java基础八股(不贴出来了),集合源码,MySQL,Redis八股部分

3)目前简历修改完毕

双非二本实习前的准备day8 第2张
()

力扣刷题

SQL

力扣1193:1193. 每月交易 I

解答思路:

        1)看注释即可

# 找出每年的每月,按每日期和国家分组
# 这里得用到日期函数DATE_FORMAT(trans_date, '%Y-%m'),可以把日期转换为指定格式
# 其余的就是按照题目提示来统计即可,使用之前学到的IF来判断
select 
        DATE_FORMAT(trans_date, '%Y-%m') as month,
        country,
        count(*) as trans_count,
        sum(if(state = 'approved',1,0)) as approved_count,
        sum(amount) as trans_total_amount,
        sum(IF(state = 'approved', amount, 0)) AS approved_total_amount
    from Transactions
    group by month,country

力扣1174:1174. 即时食物配送 II

解答思路:

        1)这道题我的首要思路就是,找到首次订单,那么就是找到订单日期最早的,因此可以使用MIN

        2)查出拥有首次订单的用户的id和订单日期后,将这个表作为子查询结果

        3)我们最后也只需要用到子查询的这两个列,因此where in(表)肯定是少不了的

        4)接下来就是判断是即时订单,还是计划订单即可

# 首先得找到首次订单,即找到订单日期最早的
select 
    round(
        sum(order_date = customer_pref_delivery_date) * 100 / count(*) 
        ,2
    ) as immediate_percentage 
    from Delivery
    where (customer_id,order_date) in (
        select customer_id,MIN(order_date)
            from Delivery
            group by customer_id
        )

力扣550:550. 游戏玩法分析 IV

解答思路:

        1)这道题的难点在于进行比例的计算,以及想到日期函数-->datediff函数的使用

        2)去看评论区大神的即可

        3)这里我就简单说两句:

                3.1)这种解法只需要找到首次登录日期,因为首次登录一定是唯一的,所以找到了首次登录的用户id以及日期,其实就相当于找到了玩家的总数了,省去了又查一次表然后distinct这种操作

                3.2)接下来就是过滤数据,将查出来的首次登录表和Activity进行左连接,找到日期差为1的用户的数据,因为是左表连接查询,所以结果条数至少为左表条数;其实根本无需关心用户到底连续登录了几天,我只需要找到连续登录两天的数据即可。

                3.3)因此,将首次登录表与Activity表连接查询是再好不过的过滤方法,过滤条件如下即可on p.player_id = a.player_id and datediff(a.event_date,p.login) = 1

                3.4)最后一步就比较简单,如果找出来的天数是不连续的,那么结果就会显示为null,因此判断一下,是null就不计算即可

# 计算从首次登录日期开始至少连续两天登录的玩家的数量,然后除以玩家总数。
# 思考如何找出玩家总数
select 
        round(
            sum(if(a.event_date is not null, 1, 0)) / count(*)
        ,2) as fraction
    from 
        (
            select player_id,min(event_date) as login
                from Activity
                group by player_id
        )as p
    left join Activity as a
    on p.player_id = a.player_id and datediff(a.event_date,p.login) = 1

算法

力扣15:15. 三数之和

解答思路:

        1)看注释即可

class Solution {
    public List threeSum(int[] nums) {
        List result = new ArrayList();
        //排序
        Arrays.sort(nums);
        //开始找三元组
        for(int i = 0;i  0){
                return result;
            }
            if (i > 0 && nums[i] == nums[i - 1]) {  
                // 去重a
                // 比如一个数组,-1,-1,0,1
                // 此时就需要这一步来去重
                continue;
            }
            //去找其余两个
            int left = i + 1;
            int right = nums.length-1;
            while(left  0){
                    right--;
                }
                //left同理
                else if(sum  left && nums[right] == nums[right - 1]) right--;
                    while (right > left && nums[left] == nums[left + 1]) left++;
                    //指针移动,准备进入下一轮
                    right--; 
                    left++;
                }
            }
        }
        return result;
    }
}

力扣383:383. 赎金信

解答思路:

       1)本题比较简单,哈希表来做即可

class Solution {
    public boolean canConstruct(String ransomNote, String magazine) {
        // shortcut
        if (ransomNote.length() > magazine.length()) {
            return false;
        }
        int[] cnt = new int[26];
        for(int i = 0;i 

    免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

    目录[+]