嵌入式开发C语言之参数传递

本文转载自C语言中的参数传递机制详解 本文尝试讨论下C中实参与形参的关系,即参数传递的问题。 1 值传递 首先看下列代码: #include <stdio.h> int main(){ int n = 1; printf(&quo...

2018-09-13 11:10:44

阅读数:21

评论数:0

嵌入式开发C语言之指向数组的指针

本文转载自:https://www.jb51.net/article/83729.htm 一维数组和指针: 对于一位数组和指针是很好理解的: 一维数组名: 对于这样的一维数组:int a[5]; a作为数组名就是我们数组的首地址, a是一个地址常量 . 首先说说常量和变量的关系,...

2018-09-12 15:45:44

阅读数:44

评论数:0

leetcode初级树

二叉树的最大深度 给定一个二叉树,找出其最大深度。 二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。 说明: 叶子节点是指没有子节点的节点。 示例: 给定二叉树 [3,9,20,null,null,15,7], 3 / \ 9 20 / \ ...

2018-09-04 20:46:35

阅读数:11

评论数:0

leetcode初级数组之旋转图像

给定一个 n × n 的二维矩阵表示一个图像。 将图像顺时针旋转 90 度。 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要使用另一个矩阵来旋转图像。 示例 1: 给定 matrix = [ [1,...

2018-08-31 14:45:29

阅读数:16

评论数:0

leetcode初级算法之两数之和

给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。 你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。 示例: 给定 nums = [2, 7, 11, 15], target = 9 因为 nums[0] + nums[1] = 2 + 7 = 9 所以返回 [0...

2018-08-31 10:18:55

阅读数:32

评论数:0

leetcode初级数组之移动零

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 示例: 输入: [0,1,0,3,12] 输出: [1,3,12,0,0] 说明: 必须在原数组上操作,不能拷贝额外的数组。 尽量减少操作次数。 //方法1:从前遍历,遇到不为0的往前...

2018-08-30 20:19:15

阅读数:35

评论数:0

leetcode初级数组之加一

给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。 最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。 你可以假设除了整数 0 之外,这个整数不会以零开头。 示例 1: 输入: [1,2,3] 输出: [1,2,4] 解释: 输入数组表示数字 123。 示例...

2018-08-30 19:28:17

阅读数:162

评论数:0

leetcode初级数组之两个数组的交集 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] 说明: 输出结果...

2018-08-30 16:21:29

阅读数:58

评论数:0

leetcode初级数组之只出现一次的数字

给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。 说明: 你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗? 示例 1: 输入: [2,2,1] 输出: 1 示例 2: 输入: [4,1,2,1,2] 输出: 4 ...

2018-08-29 21:18:31

阅读数:32

评论数:0

[转]坐在马桶上看算法:快速排序

作者:啊哈磊来源:51CTO博客 高快省的排序算法 有没有既不浪费空间又可以快一点的排序算法呢?那就是“快速排序”啦!光听这个名字是不是就觉得很高端呢。 假设我们现在对“6 1 2 7 9 3 4 5 10 8”这个10个数进行排序。首先在这个序列中随便找一个数作为基准数(...

2018-08-29 19:42:29

阅读数:35

评论数:0

leetcode初级数组之 存在重复

给定一个整数数组,判断是否存在重复元素。 如果任何值在数组中出现至少两次,函数返回 true。如果数组中每个元素都不相同,则返回 false。 示例 1: 输入: [1,2,3,1] 输出: true 示例 2: 输入: [1,2,3,4] 输出: false 示例 3: 输入:...

2018-08-29 19:35:40

阅读数:12

评论数:0

leetcode初级数组之旋转数组

给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。 示例 1: 输入: [1,2,3,4,5,6,7] 和 k = 3 输出: [5,6,7,1,2,3,4] 解释: 向右旋转 1 步: [7,1,2,3,4,5,6] 向右旋转 2 步: [6,7,1,2,3,4,...

2018-08-29 16:46:07

阅读数:30

评论数:0

leetcode初级数组之买卖股票的最佳时机 II

给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。 设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。 注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。 示例 1: 输入: [7,1,5,3,6,4] 输出: 7 ...

2018-08-29 10:06:57

阅读数:14

评论数:0

leetcode初级链表之环形链表

给定一个链表,判断链表中是否有环。 进阶: 你能否不使用额外空间解决此题? /** * Definition for singly-linked list. * struct ListNode { * int val; * struct ListNode *nex...

2018-08-27 21:27:55

阅读数:37

评论数:0

leetcode初级链表之回文链表

请判断一个链表是否为回文链表。 示例 1: 输入: 1->2 输出: false 示例 2: 输入: 1->2->2->1 输出: true 进阶: 你能否用 O...

2018-08-27 20:40:02

阅读数:35

评论数:0

leetcode初级链表之合并两个有序链表

将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例: 输入:1->2->4, 1->3->4 输出:1-&...

2018-08-27 19:39:58

阅读数:38

评论数:0

leetcode初级链表之删除链表中的节点以及导数第N个节点

请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。 现有一个链表 – head = [4,5,1,9],它可以表示为: 4 -> 5 -> 1 -&amp...

2018-08-27 09:34:01

阅读数:38

评论数:0

leetcode初级链表之反转链表,包括整个链表和m/n位置的链表

反转从位置 m 到 n 的链表。请使用一趟扫描完成反转。 说明: 1 ≤ m ≤ n ≤ 链表长度。 示例: 输入: 1->2->3->4-&a...

2018-08-16 12:36:29

阅读数:30

评论数:0

移出元素

题目描述: 给定一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,返回移除后数组的新长度。 不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。 元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。 示例 1: ...

2018-08-14 08:48:57

阅读数:243

评论数:0

leetcode初级数组之删除排序数组中的重复项

题目描述: 给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。 不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。 示例 1: 给定数组 nums = [1,1,2], 函数应该返回新的长度 2, ...

2018-08-07 20:26:31

阅读数:42

评论数:0

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