SQL50+Hot100系列(11.9)

一 SQL

1 1581 进店却从未进行交易过的顾客

题目描述

题目案例

思路分析:

我们先去使用外连接去看看关联后的表格式,从而对后续操作进行改进

sql 复制代码
select *
from Visits v
left join Transactions t on v.visit_id = t.visit_id

分析输出的结果,我们需要获取的就是这些transaction_id为null的,因为其是光看不买的那些,那就加上条件筛选呗,where transaction_id is null,然后结果如下

sql 复制代码
select *
from Visits v
left join Transactions t on v.visit_id = t.visit_id
where transaction_id is null

这样的话再对这个customer_id进行分组,分完组之后对组内的数据进行一个统计即可

这就是最终的代码

sql 复制代码
select v.customer_id,count(*) as count_no_trans
from Visits v
left join Transactions t on v.visit_id = t.visit_id
where transaction_id is null
group by v.customer_id

我再嘎巴一运行-击败百分之81.

2 1068 产品销售分析

题目描述

题目案例

思路分析

这题就是一个简单的外连接使用,使用过程当中对题目的分析可以一步一步的去实现最终的结果。

代码展示

sql 复制代码
select p.product_name,s.year,s.price
from Sales s 
left join Product p on s.product_id = p.product_id

二 算法

1 283移动零

题目描述

思路分析

这题呢,题目要求不能去进行数组的复制,那直接不就说出来怎么去实现了吗,交换元素。

但是如何交换,才能保证达到最终的结果,如何交换才能效率较高,这才是本题的考察点。

首先呢,我是去自定义了一个swap交换函数

然后定义了指针变量,left,right.以及最后的位置索引值n

初始时,left与right都是默认为0,举个例子,当初始数组为 1,2,0,0,5

那么初始时两个为0,会去判断nums[right]是不是0不是的话就会将right++,left++,将两个指针都向后移动,因为两个位置相同,所以说交换对数据没有影响,两个指针向后进行移动,移动到元素值为0的位置那么left就不动了让right向后走,找到不为0的,然后嘎巴将两个一交换,就这样持续操作,最终达到想要的效果。

代码展示

java 复制代码
class Solution {
    public void moveZeroes(int[] nums) {
        int n = nums.length,left = 0,right = 0;
        while(right < n){
            if(nums[right]!=0){
                swapMethod(nums,left,right);
                left++;
            }
            right++;
        }
    }
        public void swapMethod(int[] nums,int left ,int right){
            int temp = nums[left];
            nums[left]=nums[right];
            nums[right]=temp;
        }
}
相关推荐
uesowys3 小时前
Apache Spark算法开发指导-Factorization machines classifier
人工智能·算法
TracyCoder1233 小时前
LeetCode Hot100(26/100)——24. 两两交换链表中的节点
leetcode·链表
季明洵3 小时前
C语言实现单链表
c语言·开发语言·数据结构·算法·链表
shandianchengzi3 小时前
【小白向】错位排列|图文解释公考常见题目错位排列的递推式Dn=(n-1)(Dn-2+Dn-1)推导方式
笔记·算法·公考·递推·排列·考公
I_LPL3 小时前
day26 代码随想录算法训练营 回溯专题5
算法·回溯·hot100·求职面试·n皇后·解数独
Yeats_Liao3 小时前
评估体系构建:基于自动化指标与人工打分的双重验证
运维·人工智能·深度学习·算法·机器学习·自动化
cpp_25013 小时前
P9586 「MXOI Round 2」游戏
数据结构·c++·算法·题解·洛谷
浅念-3 小时前
C语言编译与链接全流程:从源码到可执行程序的幕后之旅
c语言·开发语言·数据结构·经验分享·笔记·学习·算法
有时间要学习4 小时前
面试150——第五周
算法·深度优先
晚霞的不甘4 小时前
Flutter for OpenHarmony 可视化教学:A* 寻路算法的交互式演示
人工智能·算法·flutter·架构·开源·音视频