![](https://img-blog.csdnimg.cn/20201014180756925.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
算法
文章平均质量分 76
Starry-
加油呗
展开
-
并查集算法
并查集算法1.概念并查集算法,Disjoint Set;是图论算法的一种,用于判断图中是否有环。2.原理假设有如下一个图,如何判断是否有环呢?图中有6个顶点,分别是[0, 1, 2, 3, 4, 5];有6条边,分别(0,1)、(1,2)、(1,3)、(2,4)、(3,4)、(2,5)【边的两个顶点不分顺序】;分别遍历每一条边,以两端的顶点为节点分别构建一棵树;然后把子树合并成一棵大树,合并过程中,如果某边的两顶点存在于大树中,则表明该图有环,否则继续合并直到全部合并。这里有两个重要的步骤:原创 2021-01-16 18:55:43 · 588 阅读 · 0 评论 -
数据结构|二叉树基本篇
二叉树1 什么是树以及树的相关概念树(Tree)是n(n>=0)个结点的有限集。n=0时称为空树。在任意一颗非空树中:1)有且仅有一个特定的称为根(Root)的结点;2)当n>1时,其余结点可分为m(m>0)个互不相交的有限集T1、T2、…、Tn,其中每一个集合本身又是一棵树,并且称为根的子树。此外,树的定义还需要强调以下两点:n>0时根结点是唯一的,不可能存...原创 2019-09-11 00:53:19 · 283 阅读 · 1 评论 -
leetCode|实现 strStr() 函数
题目:给定一个 haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回 -1。示例 1:输入: haystack = “hello”, needle = “ll”输出: 2示例 2:输入: haystack = “aaaaa”, needle = “bba”输出: -1...原创 2019-08-29 00:23:59 · 179 阅读 · 2 评论 -
leetCode|移除元素
1.题目:给定一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。示例 1:给定 nums = [3,2,2,3], val = 3,函数应该返回新的长度 2, 并且 nums 中的前...原创 2019-08-28 00:04:29 · 225 阅读 · 1 评论 -
leetCode|删除排序数组中的重复项
题目:给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。示例 1:给定数组 nums = [1,1,2],函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。你不需要考虑数组中超出新长度后面的元素。示例 2:给定...原创 2019-08-27 22:37:40 · 240 阅读 · 1 评论 -
leetCode|有效的括号
题目:给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。注意空字符串可被认为是有效字符串。示例 1:输入: “()”输出: true示例 2:输入: “()[]{}”输出: true示例 3:输入: “(]”输出: false示例 ...原创 2019-08-17 23:57:07 · 190 阅读 · 1 评论 -
算法|最长公共前缀
题目:编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串 “”。示例 1:输入: [“flower”,“flow”,“flight”]输出: “fl”示例 2:输入: [“dog”,“racecar”,“car”]输出: “”解释: 输入不存在公共前缀。说明:所有输入只包含小写字母 a-zJava代码class Solution { ...原创 2019-08-17 07:19:53 · 210 阅读 · 2 评论 -
leetCode|只出现一次的数字
题目:给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。说明:你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?示例 1:输入: [2,2,1]输出: 1示例 2:输入: [4,1,2,1,2]输出: 4Java代码class Solution { public int singleNumber(...原创 2019-08-20 07:24:43 · 299 阅读 · 0 评论 -
算法|罗马数转整数
题目:罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。字符数值I1V5X10L50C100D500M1000例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。通常情况下,罗马数字中小的数字在...原创 2019-08-14 22:36:17 · 222 阅读 · 1 评论 -
leetCode|合并两个有序链表
题目:将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。示例:输入:1->2->4, 1->3->4输出:1->1->2->3->4->4Java解题/** * Definition for singly-linked list. * public class ListNode { ...原创 2019-08-19 07:21:17 · 227 阅读 · 1 评论 -
算法|回文数判断
题目:判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数示例1:输入:121输出:true示例2:输入:10输出:false示例3:输入:-121输出:false代码:class Solution { public boolean isPalindrome(int x) { if (x < 0) { ...原创 2019-08-14 06:49:22 · 824 阅读 · 3 评论