D8-读论文D8&算法题D8【复习:单调栈830&154滑动窗口】&信也科技杯&GraphSage

830单调栈

n = int(input())
nums = list(map(int,input().split()))

N = 100010
stk = [0]*N
tt = 0

for i in range(n):
    while tt and stk[tt]>=nums[i]:
        tt -= 1
    # 如果tt等于0,是if not tt
    if not tt:
        print(-1, end=' ')
    else:
        print(stk[tt], end = ' ')
    tt += 1
    stk[tt] = nums[i]

154滑动窗口

 最后print的是hh。前面出现,后面一定出现。在找最大值时,前面比后面小,便无意义
 所以在队列中只存前面比后面大的坐标,形成单调减队列
最后输出最大值时,输出头元素,即nums[q[hh]].
n,k = map(int, input().split())
nums = list(map(int,input().split()))
N = 1000010
hh,tt = 0,-1
q = [0]*N

for i in range(n):
    x = nums[i]
    # 更改队列左边界
    if hh<=tt and q[hh]<i-k+1:
        hh += 1
    while hh<=tt and x<=nums[q[tt]]:
        tt -= 1
    tt += 1
    q[tt] = i
    
    if i>=k-1:
        print(nums[q[hh]], end = ' ')
print()

tt, hh = -1, 0
q = [0]*N
for i in range(n):
    x = nums[i]
    if hh<=tt and i-q[hh]+1>k:
        hh += 1
    while hh<=tt and x>=nums[q[tt]]:
        tt -= 1
    tt += 1
    q[tt] = i
    if i>=k-1:
    # 最后print的是hh。前面出现,后面一定出现。在找最大值时,前面比后面小,便无意义
    # 所以在队列中只存前面比后面大的坐标,形成单调减队列
    # 最后输出最大值时,输出头元素,即nums[q[hh]].
        print(nums[q[hh]], end = ' ')
        
    

滑动窗口队列中存放的是nums的下标;但是单调栈便没有感觉,应该存的是数本身?明天再做一遍,仔细体会!

左侧紧邻(第一个)小值——单调栈

在这里插入图片描述

滑动窗口-单调队列

在这里插入图片描述

信也科技杯一些有趣的问题

1、这个目录结构不错哦
-data
-model
-model_files(模型参数)
-utils(工具)
-submit提交结果
-train.py
-inference.py
–requirements.txt
-readme.md
在这里插入图片描述
2、utils工具是干什么的?
存放一些公共的方法
3、如何将.ipynb文件转换为.py
好像直接转换就可以了

torch_geometric

基于pytorch的图神经网络库,包含了很多GNN相关论文中的实现方法数据集

https://zhuanlan.zhihu.com/p/142948273

查看pytorch版本

import torch 
print(torch.__version__)

在这里插入图片描述

修改pytorch版本

!pip install torch==1.6.0 torchvision
安装之后,注释掉,重启就可以了~

查看colab python版本

!python --version

GraphSAGE

hhh看了视频with paper,还要看几篇中文总结才好。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值