
C算法
.REVOLUTION.
这个作者很懒,什么都没留下…
展开
专栏收录文章
- 默认排序
- 最新发布
- 最早发布
- 最多阅读
- 最少阅读
-
#算法#排序~堆排序
#include <iostream>#include <vector>using namespace std;/*class MaxHeap {private: vector<int> heap; int max_size = 0; void swap(vector<int>& arr, int a, int b) { int tmp = arr[a]; arr[a] = arr[b.原创 2021-04-07 15:29:47 · 120 阅读 · 0 评论 -
leet485. 最大连续1的个数
题目:给定一个二进制数组, 计算其中最大连续1的个数。示例 1:输入: [1,1,0,1,1,1]输出: 3解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3.注意:输入的数组只包含0 和1。输入数组的长度是正整数,且不超过 10,000。来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/max-consecutive-ones著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。思.原创 2020-11-30 13:53:23 · 230 阅读 · 0 评论 -
leet25.K 个一组翻转链表
题目:给你一个链表,每k个节点一组进行翻转,请你返回翻转后的链表。k是一个正整数,它的值小于或等于链表的长度。如果节点总数不是k的整数倍,那么请将最后剩余的节点保持原有顺序。示例:给你这个链表:1->2->3->4->5当k= 2 时,应当返回: 2->1->4->3->5当k= 3 时,应当返回: 3->2->1->4->5说明:你的算法只能使用常数的额外空间。你不能...原创 2020-10-30 10:42:38 · 123 阅读 · 0 评论 -
leet面试题 01.08. 零矩阵
编写一种算法,若M × N矩阵中某个元素为0,则将其所在的行与列清零。示例 1:输入:[ [1,1,1], [1,0,1], [1,1,1]]输出:[ [1,0,1], [0,0,0], [1,0,1]]示例 2:输入:[ [0,1,2,0], [3,4,5,2], [1,3,1,5]]输出:[ [0,0,0,0], [0,4,5,0], [0,3,1,0]]来源:力扣(LeetCode)链接:https://le...原创 2020-10-27 16:03:32 · 176 阅读 · 0 评论 -
#环境配置#Win10配置VScode c++开发环境
本文章按照以下7个流程解答,读者可根据自己需要自行跳过某个步骤:1. 下载VScode2. 安装C++拓展工具3. 下载MinGW4. 配置环境变量5. 使用简单的.cpp文件测试6.常见问题解答1、VScode下载这个比较简单可以直接去官网自行下载,传送门!!https://code.visualstudio.com/2、下载VScode之后安装C/C++开发套件由于楼主已经安装故 第3步右下角没有绿色的Install。成功安装后接下来下载编译器M...原创 2020-08-12 13:48:22 · 1888 阅读 · 0 评论 -
leet724. 寻找数组的中心索引-----前缀和
问题:给定一个整数类型的数组nums,请编写一个能够返回数组 “中心索引” 的方法。我们是这样定义数组 中心索引 的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相加的和。如果数组不存在中心索引,那么我们应该返回 -1。如果数组有多个中心索引,那么我们应该返回最靠近左边的那一个。示例 1:输入:nums = [1, 7, 3, 6, 5, 6]输出:3解释:索引 3 (nums[3] = 6) 的左侧数之和 (1 + 7 + 3 = 11),与右侧数之和 (5 + ..原创 2020-07-30 20:08:46 · 199 阅读 · 0 评论 -
leet98. 验证二叉搜索树
题目:给定一个二叉树,判断其是否是一个有效的二叉搜索树。假设一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。示例1:输入: 2 / \ 1 3输出: true示例2:输入: 5 / \ 1 4 / \ 3 6输出: false解释: 输入为: [5,1,4,null,null,3,6]。 根节点的值为 ...原创 2020-05-29 12:18:02 · 202 阅读 · 0 评论 -
leet38.外观数列
问题外观数列「外观数列」是一个整数序列,从数字 1 开始,序列中的每一项都是对前一项的描述。前五项如下:1. 12. 113. 214. 12115. 1112211被读作"one 1"("一个一") , 即11。11被读作"two 1s"("两个一"), 即21。21被读作"one 2", "one 1"("一个二","一个一"), 即1211。给定一个正整数n(1 ≤n≤ 30),输出外观...原创 2020-05-23 14:57:56 · 230 阅读 · 0 评论 -
leet7.整数翻转
问题:给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。示例1:输入: 123输出: 321示例 2:输入: -123输出: -321示例 3:输入: 120输出: 21注意:假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为[−231, 231− 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。拓展:个人本地测试过long和int内置类型的大小,当发现都为4字节。long并没有提供更大的存储...原创 2020-05-15 13:28:22 · 186 阅读 · 0 评论 -
leet104.二叉树的最大深度 & 二叉树的遍历方法-先序、中序、后序、层次
题目:给定一个二叉树,找出其最大深度。二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。说明:叶子节点是指没有子节点的节点。示例:给定二叉树[3,9,20,null,null,15,7],返回它的最大深度3 。拓展:二叉树的遍历方法二叉树的遍历: 二叉树的遍历是指从根结点出发,按照某种次序依次访问二叉树中所有结点,使得每个结点被访问一次...原创 2020-05-02 17:36:31 · 385 阅读 · 0 评论 -
leet141. 环形链表
题目:给定一个链表,判断链表中是否有环。为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则在该链表中没有环。示例 1:输入:head = [3,2,0,-4], pos = 1输出:true解释:链表中有一个环,其尾部连接到第二个节点。示例2:输入:head = [1,2], pos =...原创 2020-04-26 17:56:07 · 178 阅读 · 0 评论 -
leet234. 回文链表
题目:回文链表请判断一个链表是否为回文链表。示例 1:输入: 1->2输出: false示例 2:输入: 1->2->2->1输出: true进阶:你能否用O(n) 时间复杂度和 O(1) 空间复杂度解决此题?/**Problem: 回文链表 请判断一个链表是否为回文链表。 @author:G...原创 2020-04-25 14:14:18 · 144 阅读 · 0 评论 -
leet21. 合并两个有序链表
题目将两个升序链表合并为一个新的升序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。示例:输入:1->2->4, 1->3->4输出:1->1->2->3->4->4来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/merge-two-sorted...原创 2020-04-24 16:00:47 · 229 阅读 · 0 评论 -
leet19. 删除链表的倒数第N个节点
题目给定一个链表,删除链表的倒数第n个节点,并且返回链表的头结点。示例:给定一个链表: 1->2->3->4->5, 和 n = 2.当删除了倒数第二个节点后,链表变为 1->2->3->5.说明:给定的 n保证是有效的。进阶:你能尝试使用一趟扫描实现吗?来源:力扣(LeetCode)链接:https://leet...原创 2020-04-21 16:37:48 · 175 阅读 · 0 评论 -
leet_278. 第一个错误的版本
题目:你是产品经理,目前正在带领一个团队开发新的产品。不幸的是,你的产品的最新版本没有通过质量检测。由于每个版本都是基于之前的版本开发的,所以错误的版本之后的所有版本都是错的。假设你有 n 个版本 [1, 2, ..., n],你想找出导致之后所有版本出错的第一个错误的版本。你可以通过调用bool isBadVersion(version)接口来判断版本号 version 是否在单...原创 2020-04-20 12:30:21 · 238 阅读 · 0 评论 -
leet8. 字符串转换整数 (atoi)
题目请你来实现一个atoi函数,使其能将字符串转换成整数。首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。接下来的转化规则如下:如果第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字字符组合起来,形成一个有符号整数。假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成一个整数。该字符串在有效的整数部分之后也可能会...原创 2020-04-15 19:26:58 · 276 阅读 · 0 评论 -
leet36. 有效的数独
题目判断一个9x9 的数独是否有效。只需要根据以下规则,验证已经填入的数字是否有效即可。数字1-9在每一行只能出现一次。数字1-9在每一列只能出现一次。数字1-9在每一个以粗实线分隔的3x3宫内只能出现一次。数独部分空格内已填入了数字,空白格用'.'表示。示例1:输入:[ ["5","3",".",".","7",".",".",".",...原创 2020-04-10 10:52:19 · 245 阅读 · 0 评论 -
leet191. 位1的个数
拓展:基本数据源类型:定义的其他特殊数据类型:数据类型 占有字节数 uint8_t 1个·字节 uint16_t 2个字节 uint32_t 3个字节 uint64_t 4个字节 1、类型来源:这些数据类型中都带有_t,_t表示这些数据类型是通过typedef定义的,而不是新的数据类型。2、使用原因:方便代码的维护。比如,...原创 2020-04-09 08:58:26 · 272 阅读 · 0 评论 -
leet461. 汉明距离
题目两个整数之间的汉明距离指的是这两个数字对应二进制位不同的位置的数目。给出两个整数 x 和 y,计算它们之间的汉明距离。注意:0 ≤ x, y < 231.示例:输入: x = 1, y = 4输出: 2解释:1 (0 0 0 1)4 (0 1 0 0) ↑ ↑上面的箭头指出了对应二进制位不同的位置。来源:力扣(LeetC...原创 2020-04-08 16:21:41 · 162 阅读 · 0 评论 -
leet412. Fizz Buzz
题目:写一个程序,输出从 1 到n数字的字符串表示。1. 如果n是3的倍数,输出“Fizz”;2. 如果n是5的倍数,输出“Buzz”;3.如果n同时是3和5的倍数,输出 “FizzBuzz”。示例:n = 15,返回:[ "1", "2", "Fizz", "4", "Buzz", "Fizz", ...原创 2020-04-07 11:18:41 · 180 阅读 · 0 评论 -
leet237. 删除链表中的节点
拓展:单链表删除指定值的结点方法一: 设置两个指针一个为pre 用于指向待删除节点的前驱节点,一个为工作节点work 用于查找指定值的节点。操作思路:找到指定节点work后做如下操作pre->next = work->next ; work->next = NULL ;free(work)方法二:...原创 2020-04-06 11:40:33 · 195 阅读 · 0 评论 -
leet387. 字符串中的第一个唯一字符
给定一个字符串,找到它的第一个不重复的字符,并返回它的索引。如果不存在,则返回 -1。案例:s = "leetcode"返回 0.s = "loveleetcode",返回 2.注意事项:您可以假定该字符串只包含小写字母。来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/first-unique-character-...原创 2020-04-05 11:49:47 · 168 阅读 · 0 评论 -
leet326. 3的幂
给定一个整数,写一个函数来判断它是否是 3的幂次方。示例 1:输入: 27输出: true示例 2:输入: 0输出: false示例 3:输入: 9输出: true示例 4:输入: 45输出: false进阶:你能不使用循环或者递归来完成本题吗?来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/pow...原创 2020-04-03 09:59:40 · 175 阅读 · 0 评论 -
leet204. 计数质数
统计所有小于非负整数n的质数的数量。示例:输入: 10输出: 4解释: 小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。拓展:厄拉多塞筛法先将2-N的各数放入表中,然后在2的上面画一个圆圈,然后划去2的其他倍数;第一个既未画圈又没有被划去的数是3,将它画圈,再划去3的其他倍数;现在既未画圈又没有被划去的第一个数 是5,将它画圈,并划去5的其他倍数……依...原创 2020-04-02 19:06:39 · 211 阅读 · 0 评论 -
leet88. 合并两个有序数组
给你两个有序整数数组 nums1 和 nums2,请你将 nums2 合并到 nums1 中,使 num1 成为一个有序数组。说明:初始化 nums1 和 nums2 的元素数量分别为 m 和 n 。你可以假设 nums1 有足够的空间(空间大小大于或等于 m + n)来保存 nums2 中的元素。示例:输入:nums1 = [1,2,3,0,0,0], m = 3nums2 = [...原创 2020-03-29 09:03:58 · 191 阅读 · 0 评论 -
leet125. 验证回文串
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。说明:本题中,我们将空字符串定义为有效的回文串。示例 1:输入: "A man, a plan, a canal: Panama"输出: true示例 2:输入: "race a car"输出: false来源:力扣(LeetCode)链接:https://leetcode-cn.com/p...原创 2020-03-27 19:30:20 · 190 阅读 · 0 评论 -
leet242.有效的字母异位词
给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。示例1:输入: s = "anagram", t = "nagaram"输出: true示例 2:输入: s = "rat", t = "car"输出: false说明:你可以假设字符串只包含小写字母。进阶:如果输入字符串包含 unicode 字符怎么办?你能否调整你的解法来应对这种情况?...原创 2020-03-26 08:39:36 · 204 阅读 · 0 评论 -
leet1. 两数之和 & c++ map
给定一个整数数组 nums和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。示例:给定 nums = [2, 7, 11, 15], target = 9因为 nums[0] + nums[1] = 2 + 7 = 9所以返回 [0, 1]来源:...原创 2020-03-23 17:26:35 · 216 阅读 · 0 评论 -
leet283. 移动零
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。示例:输入: [0,1,0,3,12]输出: [1,3,12,0,0]说明:必须在原数组上操作,不能拷贝额外的数组。尽量减少操作次数。来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/move-zeroes著作权归领扣网/...原创 2020-03-23 16:59:58 · 206 阅读 · 0 评论 -
leet136.只出现一次的数
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。说明:你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?示例 1:输入: [2,2,1]输出: 1示例2:输入: [4,1,2,1,2]输出: 4来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/s...原创 2020-03-22 15:44:19 · 150 阅读 · 0 评论 -
leet122. 买卖股票的最佳时机 II
给定一个数组,它的第i 个元素是一支给定股票第 i 天的价格。设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。示例 1:输入: [7,1,5,3,6,4]输出: 7解释: 在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖出, 这笔交...原创 2020-03-21 18:28:31 · 149 阅读 · 0 评论 -
leet_66加一
给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。你可以假设除了整数 0 之外,这个整数不会以零开头。示例1:输入: [1,2,3]输出: [1,2,4]解释: 输入数组表示数字 123。示例2:输入: [4,3,2,1]输出: [4,3,2,2]解释: 输入数组表示数字 4321...原创 2020-03-20 18:02:28 · 142 阅读 · 0 评论 -
leet350. 两个数组的交集 II
给定两个数组,编写一个函数来计算它们的交集。示例 1:输入: nums1 = [1,2,2,1], nums2 = [2,2]输出: [2,2]示例 2:输入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]输出: [4,9]说明:输出结果中每个元素出现的次数,应与元素在两个数组中出现的次数一致。 我们可以不考虑输出结果的顺序。进阶:...原创 2020-03-19 15:21:13 · 134 阅读 · 0 评论