自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+

JiYou的博客

一直在努力学深度学习的小白

  • 博客(43)
  • 收藏
  • 关注

原创 通过PyTorch实现风格迁移

一.环境及数据集准备pytorch 1.1.0torchvision 0.3.0cuda 9.0数据集用的是COCO2014的train2014训练集,使用ImageNet也可以需要用到在ImageNet上预训练好的VGG16,模型文件为vgg16-397923af.pth二.原理​ 首先需要明白一点,深度学习之所以被称为“深度”,就在于它采用了深层的网络结构,网络的不同层学到的是图...

2019-11-06 21:41:32 4648 11

原创 通过PyTorch用DCGAN生成动漫头像

数据集数据集我们用AnimeFaces数据集,共5万多张动漫头像。https://pan.baidu.com/s/1eSifHcA 提取码:g5qa要把所有的图片保存于data/face/目录下,后边用ImageFolder就能直接读取到。模型模型我们选择DCGAN。#coding:utf-8from torch import nnclass NetG(nn.Module):...

2019-10-20 21:08:17 2159 3

原创 PyTorch对ResNet网络的实现解析

PyTorch对ResNet网络的实现解析我在博客园的这篇文章1.首先导入需要使用的包import torch.nn as nnimport torch.utils.model_zoo as model_zoo# 默认的resnet网络,已预训练model_urls = { 'resnet18': 'https://download.pytorch.org/models/re...

2019-07-30 20:54:47 562

原创 每日算法35_2020-12-20

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一316. 去除重复字母给你一个字符串 s ,请你去除字符串中重复的字母,使得每个字母只出现一次。需保证 返回结果的字典序最小(要求不能打乱其他字符的相对位置)。示例 1:输入:s = “bcabc”输出:“abc”示例 2:输入:s = “cbacdcbc”输出:“acdb”提示:1 <= s.length <= 104s 由小写英文字母组成没做出来官方答案:贪心+单调栈.

2020-12-20 22:58:46 145

原创 每日算法33_2020-12-09

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一62. 不同路径一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为“Start” )。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为“Finish”)。问总共有多少条不同的路径?示例 1:输入: m = 3, n = 2输出: 3解释:从左上角开始,总共有 3 条路径可以到达右下角。向右 -> 向右 -> 向下向右 ->.

2020-12-09 09:27:55 239

原创 每日算法32_2020-12-08

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一842. 将数组拆分成斐波那契序列给定一个数字字符串 S,比如 S = “123456579”,我们可以将它分成斐波那契式的序列 [123, 456, 579]。形式上,斐波那契式序列是一个非负整数列表 F,且满足:0 <= F[i] <= 2^31 - 1,(也就是说,每个整数都符合 32 位有符号整数类型);F.length >= 3;对于所有的0 <= i < F.

2020-12-08 10:20:18 145

原创 每日算法31_2020-12-07

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一861. 翻转矩阵后的得分有一个二维矩阵 A 其中每个元素的值为 0 或 1 。移动是指选择任一行或列,并转换该行或列中的每一个值:将所有 0 都更改为 1,将所有 1 都更改为 0。在做出任意次数的移动后,将该矩阵的每一行都按照二进制数来解释,矩阵的得分就是这些数字的总和。返回尽可能高的分数。示例:输入:[[0,0,1,1],[1,0,1,0],[1,1,0,0]]输出:39解释:转换为 .

2020-12-07 10:42:11 106

原创 每日算法30_2020-12-06

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一5618. K 和数对的最大数目给你一个整数数组 nums 和一个整数 k 。每一步操作中,你需要从数组中选出和为 k 的两个整数,并将它们移出数组。返回你可以对数组执行的最大操作数。示例 1:输入:nums = [1,2,3,4], k = 5输出:2解释:开始时 nums = [1,2,3,4]:移出 1 和 4 ,之后 nums = [2,3]移出 2 和 3 ,之后 nums = .

2020-12-07 10:41:29 135

原创 第四周:Python反射

反射(reflection):指的是在运行时获取类型的定义信息。本质:利用字符串的形式去对象(模块)中操作(查找/获取/删除/添加)成员,是一种基于字符串的事件驱动。简单来说,Python可以通过字符串来操作对象(类/方法/模块的)属性和方法(也可操作类),这就是Python的反射。在Python中实例化对象、类、当前模块、其他模块可以使用反射机制。Python反射的四个方法getattr(obj, name,default):获取指定对象的属性从对象和类中获取属性/方法class A

2020-12-04 17:37:43 190

原创 每日算法28_2020-12-04

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一659. 分割数组为连续子序列给你一个按升序排序的整数数组 num(可能包含重复数字),请你将它们分割成一个或多个子序列,其中每个子序列都由连续整数组成且长度至少为 3 。如果可以完成上述分割,则返回 true ;否则,返回 false 。示例 1:输入: [1,2,3,3,4,5]输出: True解释:你可以分割出这样两个连续子序列 :1, 2, 33, 4, 5示例 2:输入: [1.

2020-12-04 10:36:43 94

原创 每日算法27_2020-12-03

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一204. 计数质数统计所有小于非负整数 n 的质数的数量。示例 1:输入:n = 10输出:4解释:小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。示例 2:输入:n = 0输出:0示例 3:输入:n = 1输出:0提示:0 <= n <= 5 * 106我的答案暴力枚举class Solution { public int countPr.

2020-12-03 19:25:40 79

原创 每日算法26_2020-12-02

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一321. 拼接最大数给定长度分别为 m 和 n 的两个数组,其元素由 0-9 构成,表示两个自然数各位上的数字。现在从这两个数组中选出 k (k <= m + n) 个数字拼接成一个新的数,要求从同一个数组中取出的数字保持其在原数组中的相对顺序。求满足该条件的最大数。结果返回一个表示该最大数的长度为 k 的数组。说明: 请尽可能地优化你算法的时间和空间复杂度。示例 1:输入:nums1 = .

2020-12-02 14:52:24 92

原创 每日算法25_2020-12-01

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一34. 在排序数组中查找元素的第一个和最后一个位置给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。如果数组中不存在目标值 target,返回 [-1, -1]。进阶:你可以设计并实现时间复杂度为 O(log n) 的算法解决此问题吗?示例 1:输入:nums = [5,7,7,8,8,10], target = 8输出:[3,4].

2020-12-01 14:24:58 82

原创 每日算法24_2020-11-30

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一767. 重构字符串给定一个字符串S,检查是否能重新排布其中的字母,使得两相邻的字符不同。若可行,输出任意可行的结果。若不可行,返回空字符串。示例 1:输入: S = “aab”输出: “aba”示例 2:输入: S = “aaab”输出: “”注意:S 只包含小写字母并且长度在[1, 500]区间内。我没做出来没悟到maxCharCounts > (length + 1) / .

2020-11-30 15:39:07 107

原创 每日算法23_2020-11-29

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一976. 三角形的最大周长给定由一些正数(代表长度)组成的数组 A,返回由其中三个长度组成的、面积不为零的三角形的最大周长。如果不能形成任何面积不为零的三角形,返回 0。示例 1:输入:[2,1,2]输出:5示例 2:输入:[1,2,1]输出:0示例 3:输入:[3,2,3,4]输出:10示例 4:输入:[3,6,2,3]输出:8提示:3 <= A.length <.

2020-11-29 13:04:03 141

原创 每日算法22_2020-11-28

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一493. 翻转对给定一个数组 nums ,如果 i < j 且 nums[i] > 2*nums[j] 我们就将 (i, j) 称作一个重要翻转对。你需要返回给定数组中的重要翻转对的数量。示例 1:输入: [1,3,2,3,1]输出: 2示例 2:输入: [2,4,3,5,1]输出: 3注意:给定数组的长度不会超过50000。输入数组中的所有数字都在32位整数的表示范围内。.

2020-11-29 09:00:50 135

原创 每日算法21_2020-11-27

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一454. 四数相加 II给定四个包含整数的数组列表 A , B , C , D ,计算有多少个元组 (i, j, k, l) ,使得 A[i] + B[j] + C[k] + D[l] = 0。为了使问题简单化,所有的 A, B, C, D 具有相同的长度 N,且 0 ≤ N ≤ 500 。所有整数的范围在 -228 到 228 - 1 之间,最终结果不会超过 231 - 1 。例如:输入:A = .

2020-11-28 12:24:08 91

原创 每日算法20_2020-11-26

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一164. 最大间距给定一个无序的数组,找出数组在排序之后,相邻元素之间最大的差值。如果数组元素个数小于 2,则返回 0。示例 1:输入: [3,6,9,1]输出: 3解释: 排序后的数组是 [1,3,6,9], 其中相邻元素 (3,6) 和 (6,9) 之间都存在最大差值 3。示例 2:输入: [10]输出: 0解释: 数组元素个数小于 2,因此返回 0。说明:你可以假设数组中所有元素.

2020-11-26 10:42:51 101

原创 每日算法19_2020-11-25

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一1370. 上升下降字符串给你一个字符串 s ,请你根据下面的算法重新构造字符串:从 s 中选出 最小 的字符,将它 接在 结果字符串的后面。从 s 剩余字符中选出 最小 的字符,且该字符比上一个添加的字符大,将它 接在 结果字符串后面。重复步骤 2 ,直到你没法从 s 中选择字符。从 s 中选出 最大 的字符,将它 接在 结果字符串的后面。从 s 剩余字符中选出 最大 的字符,且该字符比上一个添.

2020-11-25 13:38:06 117

原创 每日算法18_2020-11-24

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一222. 完全二叉树的节点个数给出一个完全二叉树,求出该树的节点个数。说明:完全二叉树的定义如下:在完全二叉树中,除了最底层节点可能没填满外,其余每层节点数都达到最大值,并且最下面一层的节点都集中在该层最左边的若干位置。若最底层为第 h 层,则该层包含 1~ 2h 个节点。示例:输入: 1 / \ 2 3 / \ /4 5 6输出: 6暴力法递归法/** .

2020-11-25 13:37:46 80

原创 每日算法17_2020-11-23

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一452. 用最少数量的箭引爆气球在二维空间中有许多球形的气球。对于每个气球,提供的输入是水平方向上,气球直径的开始和结束坐标。由于它是水平的,所以纵坐标并不重要,因此只要知道开始和结束的横坐标就足够了。开始坐标总是小于结束坐标。一支弓箭可以沿着 x 轴从不同点完全垂直地射出。在坐标 x 处射出一支箭,若有一个气球的直径的开始和结束坐标为 xstart,xend, 且满足 xstart ≤ x ≤ xen.

2020-11-25 13:07:59 148

原创 每日算法16_2020-11-22

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一242. 有效的字母异位词给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。示例 1:输入: s = “anagram”, t = “nagaram”输出: true示例 2:输入: s = “rat”, t = “car”输出: false说明:你可以假设字符串只包含小写字母。进阶:如果输入字符串包含 unicode 字符怎么办?你能否调整你的解法来应对这.

2020-11-25 13:07:39 75

原创 每日算法15_2020-11-21

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一148. 排序链表给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。进阶:你可以在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序吗?示例 1:输入:head = [4,2,1,3]输出:[1,2,3,4]示例 2:输入:head = [-1,5,3,4,0]输出:[-1,0,3,4,5]示例 3:输入:head = []输出:[]提示:.

2020-11-25 13:04:17 84

原创 每日算法14_2020-11-20

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一147. 对链表进行插入排序对链表进行插入排序。插入排序的动画演示如上。从第一个元素开始,该链表可以被认为已经部分排序(用黑色表示)。每次迭代时,从输入数据中移除一个元素(用红色表示),并原地将其插入到已排好序的链表中。插入排序算法:插入排序是迭代的,每次只移动一个元素,直到所有元素可以形成一个有序的输出列表。每次迭代中,插入排序只从输入数据中移除一个待排序的元素,找到它在序列中适当的位置,并将其.

2020-11-25 13:03:52 92

原创 每日算法13_2020-11-19

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一283. 移动零给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。示例:输入: [0,1,0,3,12]输出: [1,3,12,0,0]说明:必须在原数组上操作,不能拷贝额外的数组。尽量减少操作次数。我的答案class Solution { public void moveZeroes(int[] nums) { int z.

2020-11-25 12:59:34 104

原创 每日算法12_2020-11-18

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一105. 从前序与中序遍历序列构造二叉树根据一棵树的前序遍历与中序遍历构造二叉树。注意:你可以假设树中没有重复的元素。例如,给出前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7]返回如下的二叉树: 3 / \ 9 20 / \ 15 7我的答案递归/** * Definition for .

2020-11-25 12:59:04 83

原创 每日算法11_2020-11-17

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一101. 对称二叉树给定一个二叉树,检查它是否是镜像对称的。例如,二叉树 [1,2,2,3,4,4,3] 是对称的。 1 / \ 2 2 / \ / \3 4 4 3但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的: 1 / \ 2 2 \ \ 3 3进阶:你可以运用递归和迭代两种方法解决这个问题吗?我的答.

2020-11-25 12:58:37 124

原创 每日算法10_2020-11-15

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一104. 二叉树的最大深度给定一个二叉树,找出其最大深度。二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。说明: 叶子节点是指没有子节点的节点。示例:给定二叉树 [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回它的最大深度 3 。我的答案递归/** * Definition for a binary t.

2020-11-24 11:07:19 108

原创 每日算法9_2020-11-14

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一94. 二叉树的中序遍历给定一个二叉树的根节点 root ,返回它的 中序 遍历。示例 1:输入:root = [1,null,2,3]输出:[1,3,2]示例 2:输入:root = []输出:[]示例 3:输入:root = [1]输出:[1]示例 4:输入:root = [1,2]输出:[2,1]示例 5:输入:root = [1,null,2]输出:[1,2]提示:.

2020-11-24 11:03:42 300

原创 每日算法8_2020-11-13

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一21. 合并两个有序链表将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。示例:输入:1->2->4, 1->3->4输出:1->1->2->3->4->4我的答案我没有答案,太菜了好的答案(看不太懂)class Solution { public ListNode mergeTwoLi.

2020-11-24 11:03:08 304

原创 每日算法7_2020-11-11

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一13. 罗马数字转整数罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。字符 数值I 1V 5X 10L 50C 100D 500M 1000例如, 罗马数字 2 写做 II ,即为两个并列.

2020-11-24 10:58:05 106

原创 每日算法6_2020-11-10

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一1. 两数之和难度简单9570收藏分享切换为英文接收动态反馈给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。示例:给定 nums = [2, 7, 11, 15], target = 9因为 nums[0] + nums[1] = 2 + 7 = 9.

2020-11-24 10:57:34 73

原创 每日算法5_2020-06-22

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一一维数组的动态和给你一个数组 nums 。数组「动态和」的计算公式为:runningSum[i] = sum(nums[0]…nums[i]) 。请返回 nums 的动态和。我的解答class Solution { public int[] runningSum(int[] nums) { int[] ret = new int[nums.length]; in.

2020-11-24 10:57:02 422

原创 每日算法4_2020-06-10

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一LCP 01. 猜数字​ 小A 和 小B 在玩猜数字。小B 每次从 1, 2, 3 中随机选择一个,小A 每次也从 1, 2, 3 中选择一个猜。他们一共进行三次这个游戏,请返回 小A 猜对了几次?​ 输入的guess数组为 小A 每次的猜测,answer数组为 小B 每次的选择。guess和answer的长度都等于3。示例1:输入:guess = [1,2,3], answer = [1,2,3].

2020-11-24 10:56:14 139

原创 每日算法3_2020-06-09

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一面试题58 - II. 左旋转字符串字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。示例1:输入: s = "abcdefg", k = 2输出: "cdefgab"示例2:输入: s = "lrloseumgh", k = 6输出: "um.

2020-11-24 10:55:46 55

原创 每日算法2_2020-06-08

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一给你一个数组 candies 和一个整数 extraCandies ,其中 candies[i] 代表第 i 个孩子拥有的糖果数目。对每一个孩子,检查是否存在一种方案,将额外的 extraCandies 个糖果分配给孩子们之后,此孩子有 最多 的糖果。注意,允许有多个孩子同时拥有 最多 的糖果数目。示例1:输入:candies = [2,3,5,1,3], extraCandies = 3输出:[tr.

2020-11-24 10:54:27 106

原创 每日算法1_2020-06-05

来源:题库 - 力扣 (LeetCode) (leetcode-cn.com)。侵删。题目一泰波那契序列 Tn 定义如下:T0 = 0, T1 = 1, T2 = 1, 且在 n >= 0 的条件下 Tn+3 = Tn + Tn+1 + Tn+2给你整数 n,请返回第 n 个泰波那契数 Tn 的值。示例 1:输入:n = 4输出:4解释:T_3 = 0 + 1 + 1 = 2T_4 = 1 + 1 + 2 = 4示例 2:输入:n = 25输出:1389537提示:.

2020-11-24 10:53:03 85

原创 第三周:Python抽象类

Python抽象类在Python中抽象类只能被继承,不能被实例化。并且,抽象类中只有抽象方法和普通方法。定义抽象类和抽象方法Python的抽象类的定义需要abc模块。(= =…)# 导入抽象类需要用到的库from abc import ABCMeta, abstractmethodclass Person(metaclass=ABCMeta): """使用元类(模板类)""" pname = "这是Person抽象类" # 可以定义属性 # 定义

2020-11-23 14:31:24 385

原创 第二周:Python3的内存管理

Python3的内存管理运行的Python3版本为3.6.4。IDE为PyCharm2018.首先x = 20这里的x是在Python3中是一个引用,指向对象20。其次,通过id()方法可以来查看对象的地址,该方法返回值为十进制数值。那么c = 2.0d = 2.0print(id(c), id(d), id(2.0)) # 2591934537544 2591934537544 2591934537544print(c == d) # Trueprint(c is d)

2020-11-16 18:54:11 260

原创 第一周:JDBC中批量插入数据问题

JDBC中批量插入数据问题在向数据库中添加数据时,难免会遇到批量添加数据的问题。下面就是使用JDBC来实现批量插入的几种方法。准备工作:在MySQL5数据库中创建一个names表表中就两个字段id:主键,自增name:varchar(25),保证长度够用就行CREATE TABLE names( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(25));方法一:最直接的频繁执行SQL语句来插入long start = Sy

2020-11-07 15:37:22 396

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除