题目: 给定两个大小为 m 和 n 的有序数组 nums1 和 nums2。 示例 1: nums1 = [1, 3] nums2 = [2] 则中位数是 2.0 示例 2: nums1 = [1, 2] nums2 = [3, 4] 则中位数是 (2 + 3)/2 = 2.5 ...
问题: 给你两个排序的数组,求两个数组的交集。 比如: A , B , 那么交集就是 ,n是a数组大小,m是b数组大小。 思路: 从b数组遍历取值,然后把值与a数组的每一个值进行比较,如果有相等的,就保存下来,直到ab全部遍历完,这样时间复杂度就是O nm 。 把上面的改进一下,我们在把b里面的值与a比较时,我们采取二分搜索的方式 因为数组都是有序的 ,这样的话时间复杂度就会变为O mlogn , ...
2018-06-04 13:03 0 1822 推荐指数:
题目: 给定两个大小为 m 和 n 的有序数组 nums1 和 nums2。 示例 1: nums1 = [1, 3] nums2 = [2] 则中位数是 2.0 示例 2: nums1 = [1, 2] nums2 = [3, 4] 则中位数是 (2 + 3)/2 = 2.5 ...
面试题: 怎样把两个有序数组合并成有序数组呢 逻辑步骤: 1.假设两个数组为A和B 2.A和B都是从小到大的顺序进行排列 ** 1.我们可以直接比较两个数组的首元素,哪个小就把这个小元素放入可变数组。 2.把小元素所在的数组中的这个元素删除。 3.继续比较两个数组中的首 ...
好吧,这个是刚从别人那里看到的https://www.cnblogs.com/kubidemanong/p/10409712.html,学到了,先记下来。 问题:给你n个无序的int整型数组arr,并且这些整数的取值范围都在0-20之间,要你在 O(n) 的时间复杂度中把这 n 个数按照从小到大 ...
思路: 常规思路: 先将一个数组作为合并后的数组, 然后遍历第二个数组的每项元素, 一一对比, 直到找到合适的, 就插入进去; 简单思路: 设置数组C, 对比A和B数组的首项元素, 找到最小的, 就放入数组C,依次进行下去. 代码如下: 执行代码, 输入输出 ...
题目描述: 如何对n个数进行排序,要求时间复杂度O(n),空间复杂度O(1) 解析: 利用计数排序法,设置一大小为65536的int数组,范围a[0]~a[65535],并初始为0,然后遍历n个数,假设这n个数在数组array[0...n-1]中,则i取值从0到n-1同时执行 ...
一、学习借鉴 引:上一篇文章中在合并俩数组时用到了好几个for循环,因此大大增加了时间复杂度,于是找了好多关于这方面的算法。 请看下面事例: 整个过程中用到的原理都在注释中。 结果: [1, 2, 3, 4, 5, 6] 二、第一篇文章算法优化(java内部自带 ...
时间复杂度 算法分析 同一问题可用不同算法解决,而一个算法的质量优劣将影响到算法乃至程序的效率。算法分析的目的在于选择合适算法和改进算法。一个算法的评价主要从时间复杂度和空间复杂度来考虑。 一、时间复杂度 (1)时间频度 一个算法执行所耗费的时间,从理论上是不能算出来的,必须上机运行测试才能知 ...