当前位置: 首页 > wzjs >正文

做网站需要的参考文献宁波网络推广方法

做网站需要的参考文献,宁波网络推广方法,长沙自适应网站制作,孝感网站建设公司题目 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。 注意:最终,合并…

题目

给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。

请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。

注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n 。

实例

示例 1:
输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输出:[1,2,2,3,5,6]
解释:需要合并 [1,2,3] 和 [2,5,6] 。
合并结果是 [1,2,2,3,5,6] ,其中斜体加粗标注的为 nums1 中的元素。

示例 2:
输入:nums1 = [1], m = 1, nums2 = [], n = 0
输出:[1]
解释:需要合并 [1] 和 [] 。
合并结果是 [1] 。

示例 3:
输入:nums1 = [0], m = 0, nums2 = [1], n = 1
输出:[1]
解释:需要合并的数组是 [] 和 [1] 。
合并结果是 [1] 。
注意,因为 m = 0 ,所以 nums1 中没有元素。nums1 中仅存的 0 仅仅是为了确保合并结果可以顺利存放到 nums1 中。

题解

先贴代码

public static void merge(int[] nums1, int m, int[] nums2, int n) {/*****************方法一:合并后对数组进行排序***********************/
//        for (int i = 0; i < n; i++) {
//            nums1[m + i] = nums2[i];
//        }
//        Arrays.sort(nums1);/*****************方法二:双指针法***********************/
//        int nums[] = new int[m + n];
//        int p1 = 0, p2 = 0;
//        int cur = 0;
//        while(p1 < m && p2 < n){
//            if (nums1[p1]> nums2[p2]){
//                nums[cur++] = nums2[p2++];
//            } else {
//                nums[cur++] = nums1[p1++];
//            }
//        }
//        while(p1 < m){
//            nums[cur++] = nums1[p1++];
//        }
//        while(p2 < n){
//            nums[cur++] = nums2[p2++];
//        }
//        for (int i = 0; i < m + n; i++) {
//            nums1[i] = nums[i];
//        }/*****************方法三:逆向双指针法***********************/int p1 = m - 1, p2 = n - 1;int tail = m + n - 1;while (p1 >= 0 && p2 >= 0) {if (nums1[p1] > nums2[p2]) {nums1[tail--] = nums1[p1--];}else {nums1[tail--] = nums2[p2--];}}while (p2 >= 0) {nums1[tail--] = nums2[p2--];}while (p1 >= 0) {nums1[tail--] = nums1[p1--];}}

方法一

简单粗暴,先将nums2数组中的数放到nums1后面,然后对整个nums1数组进行排序。这样时间复杂度为O(m+n)lg(m+n),所需时间复杂度主要为排序操作的开销;空间复杂度为O(lg(m+n)),主要为排序所需的空间。

方法二

需要新建一个临时数组,从前往后遍历数组,每次都将较小的数先放入临时数组中。需要注意的是当某个数组遍历完成后,需要将另一数组中的值放到按照顺序放到新数组中。
时间复杂度:O(m+n)
空间复杂度:O(m+n),主要用于临时数组开销。

方法三

方法二虽然降低了时间复杂度,但是需要结束临时数据,增加了空间复杂度,方法三使用逆向双指针法,不用借助临时数据。
从后往前遍历数组,每次都将较大的数先放入数组中。
时间复杂度:O(m+n)
空间复杂度:O(1)。

http://www.dtcms.com/wzjs/406215.html

相关文章:

  • 泰安网站建设优化网页设计与制作学什么
  • div css 网站模板搜索关键词
  • 电脑经销部开具网站建设费阿里云域名注册
  • 怎么知道网站是某个公司做的做网站好的网站建设公司
  • 广州公司建设网站百度app下载官方免费最新版
  • 大型电子商务网站建设方案百度seo官方网站
  • 乐山市做网站的公司百度搜索广告收费标准
  • 做化妆品原料批发网站有哪些游戏推广员平台
  • 做的好的装修公司网站网站模板建站公司
  • 如何建设传奇网站百度推广按点击收费
  • 网络营销哪些公司好做呢三门峡网站seo
  • 网站开发基本要求什么企业需要网络营销和网络推广
  • 网站集约化建设优点百度客服转人工
  • 赣州seo公司东莞seo排名扣费
  • 成都网站制作收费steam交易链接在哪复制
  • api模式网站开发带佣金的旅游推广平台有哪些
  • 网站开发并发 性能网络营销专业就业方向
  • 法与家国建设征文网站百度百家号官网
  • 怎样在手机做自己的网站如何在网站上推广自己的产品
  • 小程序定制深圳太原seo推广外包
  • 华宁网站建设免费网站seo诊断
  • 广州大型网站设计公司最快新闻资讯在哪看
  • 没有备案的网站可以做淘宝客山东今日头条新闻
  • 一般做网站是在什么网站找素材英文关键词seo
  • 在哪里可以做网站软文代发价格
  • 做营销网站制作bing搜索国内版
  • 政府网站建设的功能seo优化关键词是什么意思
  • 艺术设计招聘网站查关键词的排名工具
  • 做网站推广优化哪家好马鞍山网站seo
  • wordpress 自定义栏目调用安卓手机优化软件排名