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

郑州招聘网站推广英语培训机构

郑州招聘网站推广,英语培训机构,windows做网站的工具,微信小程序怎么关闭定位原题请见:Leetcode189-旋转数组 1、题目描述 2、题目分析 首先容易想到的最简单的方案,是算出来移动K步之后,新数组的每一个坐标与原坐标的映射关系,然后根据映射关系放到一个全新的数组,再把新数组的值赋给原数组。…

原题请见:Leetcode189-旋转数组

1、题目描述

请添加图片描述

2、题目分析

首先容易想到的最简单的方案,是算出来移动K步之后,新数组的每一个坐标与原坐标的映射关系,然后根据映射关系放到一个全新的数组,再把新数组的值赋给原数组。

但题目描述的进阶方案,我们应该考虑使用 O(1) 复杂度实现。
这里不啰嗦,直接说结论:

任何有关数组的旋转、对称、平移的题目,优先去把题目转换成几次基本的对称。
大多数情况下都能通过有限次的对称解决。

例如本题:
假设输入条件是:[1,2,3,4,5,6,7] k = 3
第一步:先整体左右对称:[7,6,5,4,3,2,1]
第二步:根据 k = 3,做一个分割线: [7,6,5 | 4,3,2,1]
第三步:分割线左边的内容做对称,分割线右边的内容做对称 [5,6,7 | 1,2,3,4]
请添加图片描述

3、题解

class Solution {public void rotate(int[] nums, int k) {// 考虑使用原地对称的算法解决这个问题// 例如:[1,2,3,4,5,6,7] k = 3// 第一步:先整体左右对称:[7,6,5,4,3,2,1]// 第二步:根据 k = 3,做一个分割线: [7,6,5 | 4,3,2,1]// 第三步:分割线左边的内容做对称,分割线右边的内容做对称 [5,6,7 | 1,2,3,4]int minK = k % nums.length;symmetrized(nums, 0, nums.length - 1);symmetrized(nums, 0 , minK - 1);symmetrized(nums, minK, nums.length - 1);}private void symmetrized(int[] nums, int start, int end) {int mid = (start + end + 1) / 2;for (int i = 0; i + start< mid; i++) {int temp = nums[start + i];nums[start + i] = nums[end - i];nums[end - i] = temp;}}
}
http://www.hrbkazy.com/news/52921.html

相关文章:

  • 成都制作网站价格表旺道seo推广有用吗
  • 公众号怎么推广快又有效青岛seo代理计费
  • 电子商务网站开发的基本要求厦门人才网最新招聘信息网
  • 深色调网站浏览器网址
  • 大气网站后台界面外贸网站建设案例
  • 拟采用建站技术国内推广平台有哪些
  • 广告文案优秀网站网站优化
  • 昆明企业做网站自己建网站详细流程
  • 网站建设培训招生必应搜索引擎
  • 在ppt里面做网站链接镇江seo优化
  • 怎么做提升自己的网站seo外链平台热狗
  • 网站做三方登陆需要注册公司不seo推广优化外包价格
  • 相亲网站如何做影视网站怎么优化关键词排名
  • 学做窗帘的网站百度统计代码安装位置
  • 找人网站怎样创建一个网站
  • 怎么把网站做的好看推广软文是什么
  • 做园林景观的网站优化公司
  • 网站权重分析百度搜索引擎盘搜搜
  • 电脑卸载不了wordpressseo全网图文推广
  • wordpress关闭移动站点艾滋病多长时间能查出来
  • 呼和浩特市网站建设seo外链工具
  • 北京专业网站营销搜索引擎优化心得体会
  • 中国住房和城乡建设部网站武汉网络推广有哪些公司
  • 咸宁做网站2022近期时事热点素材
  • 上海个人建站模板今天最近的新闻
  • 网站中的关键词seo设置可以直接打开网站的网页
  • 密云建设网站百度手机seo
  • 整站优化哪家专业搜狗网站seo
  • 如何建立自己的个人网站seo小白入门教学
  • 重庆交通在线公众号南昌seo营销