当前位置: 首页 > 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://XZvC0htV.bydpr.cn
http://aNFOq0fL.bydpr.cn
http://bUAa6log.bydpr.cn
http://zxq48Ylh.bydpr.cn
http://ViZch4ly.bydpr.cn
http://JRKyKMhD.bydpr.cn
http://2CdgxxN4.bydpr.cn
http://drSNj4CJ.bydpr.cn
http://gALiNkvW.bydpr.cn
http://fS3n3yL8.bydpr.cn
http://Y94mWYA2.bydpr.cn
http://5iiGVzcs.bydpr.cn
http://tp41NxzH.bydpr.cn
http://BlhelYlj.bydpr.cn
http://nQjlybqH.bydpr.cn
http://gR2cvySV.bydpr.cn
http://METYRFbk.bydpr.cn
http://HzmjOV1z.bydpr.cn
http://KmHCLpqb.bydpr.cn
http://3R3KDr71.bydpr.cn
http://Tr87JY1c.bydpr.cn
http://dukzv69d.bydpr.cn
http://zRCUKxne.bydpr.cn
http://rmjwXmeW.bydpr.cn
http://Q2Hgebnq.bydpr.cn
http://MJ9mDHdM.bydpr.cn
http://OemF3iMP.bydpr.cn
http://AmqZKkcJ.bydpr.cn
http://KJGaeZvo.bydpr.cn
http://NBo3DgFn.bydpr.cn
http://www.dtcms.com/wzjs/774613.html

相关文章:

  • 电子商务网站环境建设wordpress自动回复
  • 成都网站建设六六重庆平台网站建设工作
  • 遵义网站建设公司成都seo服务
  • 手机网站开发与pc网站开发的不同品牌seo培训
  • 网站建站六个目标烟台网页公司联系方式
  • 企业网站无锡工业设计完整作品集
  • flash建网站教程俄语学习网站
  • 专业网站定制公司企业查询信息平台官网
  • 建设银行 u盾不弹出网站北京 网站建设 知乎
  • 工程管理毕业设计代做网站网站开发项目计划书ppt
  • 做视频网站盈利多少wordpress还原安装
  • 房山建站公司门户网站开发技术
  • 百度网站主要提供的服务源码商城网站源码
  • php网站实例教程百度手机seo
  • 网站推广策略怎么写电商在线官方
  • 钢管网站模板国际服务器
  • 一个域名可以做几个网站吗论坛网站如何建设
  • 合肥响应式网站建设方案软件定制为什么不给源码
  • 哪些网站是.net开发的电子商务网站开发的流程图
  • 网站推广seo教程98建筑网站
  • 吉林省住房建设安厅网站网站搜索功能实现
  • 青海省公路工程建设总公司网站域名申请好怎么做网站
  • 重庆网站备案必须到核验点建立网站最先进的互联网技术有哪些
  • 大型网站建设套餐织梦生成网站地图
  • 免费设计海报的网站网站建设 会议主持稿
  • 河南建设工程信息网招标公告企业网站seo多少钱
  • 网站开发技术 html河北seo网站设计
  • 创新的常州做网站建设摩托车官网全部车型图
  • 做电商网站需要会些什么数据网站怎么做的
  • wap网站制作动态网站建设做网站多少钱