Rotate Array
来源:互联网 发布:sql inset 编辑:程序博客网 时间:2024/06/10 11:01
题目详情:https://leetcode.com/problems/rotate-array/description/
自己写的代码:
class Solution(object): def rotate(self, nums, k): """ :type nums: List[int] :type k: int :rtype: void Do not return anything, modify nums in-place instead. """ numsLenght=len(nums) k=k%numsLenght #这是后来加上的,一开始没有意识到k有可能大于numsLength if k==0: #如果k==0,那么直接返回 print nums return diff=numsLenght-k #得到前边有多少元素需要往后移 temp=nums[diff:numsLenght] #把后边的元素,存储下来 i=diff-1 #因为下标从0开始,一共有diff个元素需要移动,最后一个元素为diff-1 while i>=0:#先将前边的元素往后移动 nums[i+k]=nums[i] i-=1 i=0 while i<k: #再将后边的元素移动前边 nums[i]=temp[i] i=i+1 print nums
模仿别人写的代码:
class Solution(object): def rotate(self, nums, k): """ :type nums: List[int] :type k: int :rtype: void Do not return anything, modify nums in-place instead. """ numsLength=len(nums) k=k%numsLength; nums[:]=nums[-k:]+nums[:-k] print nums
看见解析2(https://leetcode.com/problems/rotate-array/solution/)后
#include <sys/malloc.h>void rotate(int* nums, int numsSize, int k){ int *temp=(int*)malloc(sizeof(int)*numsSize); for(int i=0;i<numsSize;++i) { temp[(i+k)%numsSize]=nums[i]; //主要想联系一下temp数组的写法 } for(int i=0;i<numsSize;++i) { nums[i]=temp[i]; printf("%d ",temp[i]); } printf("\n" );}
阅读全文
0 0
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- rotate array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- Rotate Array
- 【POJ 1251】Jungle Roads(最小生成树)
- RHCE——向Linux系统添加磁盘、分区和文件系统
- 与SurfaceView的初次见面
- PoEdu_Windows_CreateProcess
- Servlet学习笔记
- Rotate Array
- F
- 微信小程序注册知识
- CSDN博客搬到http://blog.csdn.net/caicaiatnbu/
- Excel在统计分析中的应用—第二章—描述性统计-Part6-利用分析工具进行描述性统计
- GUI笔记
- 一个简单的磁盘挂载方式
- [机器学习入门] 李宏毅机器学习笔记-36(Ensemble part 2;集成方法 part 2)
- HDU 4662 MU Puzzle