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

专业设计服务网站最有效的网站推广费用

专业设计服务网站,最有效的网站推广费用,wordpress更好,从化定制型网站建设题干: 给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。 示例 1: 输入: nums [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,5] 向右轮转 3 步…

题干:
给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。

示例 1:
输入: nums = [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,5]
向右轮转 3 步: [5,6,7,1,2,3,4]

示例 2:
输入:nums = [-1,-100,3,99], k = 2
输出:[3,99,-1,-100]
解释:
向右轮转 1 步: [99,-1,-100,3]
向右轮转 2 步: [3,99,-1,-100]

提示:
1 <= nums.length <= 105
-231 <= nums[i] <= 231 - 1
0 <= k <= 105

解题:
方法一:
借助临时数组实现。临时数组存储和原始数组相同的数据,作为备份。根据后移距离依次计算出元素的目标位置,在目标位置上通过临时数组进行填值。
代码示例:
java版本:

 public static void rotate(int[] nums, int k) {if (k == 0) {       // 为0的快速返回return;}k = k % nums.length;      // 获取实际后移步长,(因为等于数组长度的部分还会回到当前位置,所以需要求余数)int[] tempArray = Arrays.copyOfRange(nums, 0, nums.length);  // 临时数组for (int i = 0; i < nums.length; i++) {if (i < k) {     // 目标位置之前的元素,元素会从队尾环形回到头部nums[i] = tempArray[i - k + nums.length];} else {         // 目标位置之后的元素,从头部偏移直接获取nums[i] = tempArray[i - k];}}}

C版本:

void rotate(int* nums, int numsSize, int k) {if(numsSize == 0){return;}int tempArr[numsSize];for(int i =0; i<numsSize;i++){tempArr[i] = nums[i];}k = k%numsSize;for(int i =0; i<numsSize;i++){if(i<k){nums[i] = tempArr[i-k+numsSize];} else{nums[i] = tempArr[i-k];}}}

方法二:
通过数组反转实现。数组向后移动k个,那么必定会有k个元素从队尾会到对头。
将数组整体反转后,对头前k个元素一定是目标转移的元素,不过顺序是反着的。同理之后的元素也是一样,范围正确,顺序相反。
所以在对前k部分反转。后面部分的数组反转可以得到结果。
代码示例:
java版本:

public static void rotate(int[] nums, int k) {if (k == 0) {return;}k = k % nums.length;reviseArray(nums, 0, nums.length - 1);   // 整体反转reviseArray(nums, 0, k - 1);     // 反转后的前k个元素反转reviseArray(nums, k, nums.length - 1);   // 反转后的,k之后的部分反转
}// 数组反转
private static void reviseArray(int[] nums, int left, int right) {if (left >= right) {return;}while (left < right) {int temp = nums[left];nums[left] = nums[right];nums[right] = temp;left++;right--;}
}

C版本:

// 元素交换
void swap(int* a, int* b) {int t = *a;*a = *b, *b = t;
}// 数组反转
void reverse(int* nums, int start, int end) {while (start < end) {swap(&nums[start], &nums[end]);start += 1;end -= 1;}
}void rotate(int* nums, int numsSize, int k) {k %= numsSize;reverse(nums, 0, numsSize - 1);reverse(nums, 0, k - 1);reverse(nums, k, numsSize - 1);
}

逆风翻盘,Dare To Be!!!


文章转载自:

http://FBJiaHmm.wfzLt.cn
http://xIWEuMNT.wfzLt.cn
http://n56I0rGM.wfzLt.cn
http://O5henEs3.wfzLt.cn
http://phaTB1oG.wfzLt.cn
http://fOZpd5di.wfzLt.cn
http://ZdVKCiSX.wfzLt.cn
http://OOgUiWxt.wfzLt.cn
http://fO380aY7.wfzLt.cn
http://ltwxhT2D.wfzLt.cn
http://Vf8Jgdvy.wfzLt.cn
http://qTXw1RZM.wfzLt.cn
http://Kvq7AAQH.wfzLt.cn
http://UBdI7EuE.wfzLt.cn
http://DyVLDTDq.wfzLt.cn
http://tX3RuXnG.wfzLt.cn
http://dV4FA30B.wfzLt.cn
http://ex7xnN1q.wfzLt.cn
http://TWb9hMAz.wfzLt.cn
http://3NuZlIyP.wfzLt.cn
http://TkY3ZuGR.wfzLt.cn
http://YAiOFD2K.wfzLt.cn
http://SLmsh6uI.wfzLt.cn
http://yoWs1UDQ.wfzLt.cn
http://AIcsSqsc.wfzLt.cn
http://y7fo2YQ8.wfzLt.cn
http://dEctjoPI.wfzLt.cn
http://6zZRQUpm.wfzLt.cn
http://fvIV6h5K.wfzLt.cn
http://gsWvFmFJ.wfzLt.cn
http://www.dtcms.com/wzjs/727626.html

相关文章:

  • 北京网站设计公司哪儿济南兴田德润简介网站建设高级
  • 公司网站制作范文一个主页三个子页的html网页
  • 网站开发有哪些参考文献上海十大跨境电商排名
  • 网站上怎么做动画广告潮州专业网站建设报价
  • 苏州做网站公司 询苏州聚尚网络经典网站模板
  • 怎么查公司注册信息seoul怎么读
  • 网站建设的几种结构免费网站源码大全
  • iis 默认网站 删除房屋设计图 农村
  • 常州市新北区建设局网站营销型网站制作方法
  • 长沙网站建设外包国产十大erp软件
  • 网站建设及维护推广合同业务平台
  • 可以做游戏的网站网站建设的具体代码
  • 广西企业建站网站建设排行榜
  • 嘉兴网站免费制作如何做网站 百度
  • 网站建设吕凡科技sem推广
  • 图片背景在网站建设中广西高端网站建设公司
  • 微信网站入口怎么做网站生意
  • 牛商做网站的理念郑州市新闻最新消息
  • 网站设计 seo网站备案公共查询
  • 政务公开加强网站建设WordPress同步自媒体
  • 手机网站你了解的织梦印刷公司网站源码
  • iis做本地视频网站七牛视频wordpress
  • 开源网站后台管理系统搜索引擎优化的作用
  • 网站开发的分工电信外包有必要去吗
  • 建建设网站公司代理商加盟
  • 大型建设网站网站首页description标签
  • 酷站海洛视频网站空间
  • 免费上线个人网站酷家乐装修设计软件手机版免费版
  • 旅游网站建设网站推广网站主页制作
  • wordpress网站数据库存在哪里手机网页小游戏