LeetCode-【剑指offer刷题记录汇总】-python版

经过坚持每天刷一道题目,最终刷完了LeetCode-剑指offer的题目,下面给出刷题记录列表,以便后面复习。
LeetCodeEasy-【面试题03.数组中重复的数字】
LeetCodeEasy-【面试题04.二维数组中的查找】
LeetCodeEasy-【面试题05.替换空格】
LeetCodeEasy-【面试题05.替换空格】
LeetCodeEasy-【面试题09.用两个栈实现队列】
LeetCodeEasy-【面试题10-I.斐波那契数列】
LeetCodeEasy-【面试题10-II.青蛙跳台阶问题】
LeetcodeMedium-【面试题12.矩阵中的路径】
LeetCodeEasy-【面试题11.旋转数组的最小数字】
LeetcodeMedium-【面试题13.机器人的运动范围】
LeetcodeMedium-【面试题14-I.剪绳子】
LeetcodeMedium-【面试题14-II.剪绳子II】
LeetCodeEasy-【面试题15.二进制中1的个数】
LeetcodeMedium-【面试题16.数值的整数次方】
LeetCodeEasy-【面试题17.打印从1到最大的n位数】
LeetcodeMedium-【面试题18.删除链表的节点】
LeetCodeDifficult-【面试题19.正则表达式匹配】
LeetCodeEasy-【面试题21.调整数组顺序使奇数位于偶数前面】
LeetcodeMedium-【面试题20.表示数值的字符串】
LeetCodeEasy-【面试题22.链表中倒数第k个节点】
LeetCodeEasy-【面试题24.反转链表】
LeetCodeEasy-【面试题25.合并两个排序的链表】
LeetcodeMedium-【面试题26.树的子结构】
LeetCodeEasy-【面试题27.二叉树的镜像】
LeetCodeEasy-【面试题28.对称的二叉树】
LeetCodeEasy-【面试题29.顺时针打印矩阵】
LeetCodeEasy-【面试题30.包含min函数的栈】
LeetcodeMedium-【面试题31.栈的压入、弹出序列】
LeetcodeMedium-【面试题32-I.从上到下打印二叉树】
LeetCodeEasy-【面试题32-II.从上到下打印二叉树II】
LeetcodeMedium-【面试题32-III.从上到下打印二叉树III】
LeetcodeMedium-【面试题33.二叉搜索树的后序遍历序列】
LeetcodeMedium-【面试题34.二叉树中和为某一值的路径】
LeetcodeMedium-【面试题07.重建二叉树】
LeetcodeMedium-【面试题35.复杂链表的复制】-深拷贝
LeetCodeEasy-【面试题39.数组中出现次数超过一半的数字】
LeetcodeMedium-【面试题36.二叉搜索树与双向链表】-中序遍历
LeetCodeEasy-【面试题40.最小的k个数】topk多种解法
LeetCodeEasy-【面试题38.字符串的排列】-字符串全排列
LeetCodeDifficult-【面试题37.序列化二叉树】
LeetCodeDifficult-【面试题41.数据流中的中位数】
LeetCodeEasy-【面试题42.连续子数组的最大和】
LeetcodeMedium-【面试题43.1~n整数中1出现的次数】
LeetcodeMedium-【面试题44.数字序列中某一位的数字】
LeetcodeMedium-【面试题45.把数组排成最小的数】
LeetcodeMedium-【面试题46.把数字翻译成字符串】
LeetcodeMedium-【面试题47.礼物的最大价值】
LeetcodeMedium-【面试题48.最长不含重复字符的子字符串】
LeetcodeMedium-【面试题49.丑数】*
LeetCodeEasy-【面试题50.第一个只出现一次的字符】
LeetCodeEasy-【面试题53-I.在排序数组中查找数字I】
LeetCodeEasy-【面试题53-II.0~n-1中缺失的数字】
LeetCodeEasy-【面试题52.两个链表的第一个公共节点】
LeetCodeEasy-【面试题54.二叉搜索树的第k大节点】
LeetCodeEasy-【面试题55-I.二叉树的深度】
LeetcodeMedium-【面试题49.丑数】*
LeetcodeMedium-【面试题56-I.数组中数字出现的次数】*
LeetcodeMedium-【面试题56-II.数组中数字出现的次数II】*
LeetCodeEasy-【面试题57.和为s的两个数字】
LeetCodeEasy-【面试题57-II.和为s的连续正数序列】
LeetCodeEasy-【面试题58-I.翻转单词顺序】
LeetCodeEasy-【面试题58-II.左旋转字符串】
LeetCodeEasy-【面试题59-I.滑动窗口的最大值】
LeetcodeMedium-【面试题59-II.队列的最大值】
LeetCodeEasy-【面试题60.n个骰子的点数】*
LeetCodeEasy-【面试题61.扑克牌中的顺子】
LeetCodeEasy-【圆圈中最后剩下的数字】
LeetcodeMedium-【面试题63.股票的最大利润】
LeetcodeMedium-【面试题64.求1+2+…+n】
LeetCodeEasy-【面试题65.不用加减乘除做加法】*
LeetCodeEasy-【面试题66.构建乘积数组】
LeetcodeMedium-【面试题67.把字符串转换成整数】
LeetCodeEasy-【面试题68-I.二叉搜索树的最近公共祖先】
LeetCodeEasy-【面试题68-II.二叉树的最近公共祖先】
LeetCodeDifficult-【面试题51.数组中的逆序对】*

目录生成代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2020/6/6 11:14
# @Author  : ystraw
# @Site    : 
# @File    : main.py
# @Software: PyCharm Community Edition
# @function: 自动生成某个分类下面的所有文章

import requests
from lxml import etree

def getInfo():
    # 爬取的页数:例如2页
    for page in range(2, 0, -1):
        url = 'https://blog.csdn.net/qq_39451578/category_9870113_%d.html' % page
        # print(url)
        html = requests.get(url=url).text
        # print(html)
        html = etree.HTML(html)

        a_list = html.xpath('//ul[@class="column_article_list"]/li/a/@href')
        title_list = html.xpath('//ul[@class="column_article_list"]/li/a/div/h2')
        for a, title in zip(a_list[::-1], title_list[::-1]):
            title = title.xpath('string(.)').replace(' ', '').strip().replace('原创', '')
            print('[' + title + ']' + '(' + a + ')' )
            # break

if __name__ == '__main__':
    getInfo()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ystraw_ah

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值