前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LintCode 恢复旋转排序数组题目分析代码

LintCode 恢复旋转排序数组题目分析代码

作者头像
desperate633
发布2018-08-22 10:10:19
3200
发布2018-08-22 10:10:19
举报
文章被收录于专栏:desperate633desperate633

题目

给定一个旋转排序数组,在原地恢复其排序。

说明 什么是旋转数组? 比如,原始数组为[1,2,3,4], 则其旋转数组可以是[1,2,3,4], [2,3,4,1], [3,4,1,2], [4,1,2,3]

样例 [4, 5, 1, 2, 3]->[1, 2, 3, 4, 5]

分析

这道题主要考察观察能力,显然旋转数组,不管怎么旋转,由于之前是排好序的,所以找到比第一个数小的第一个数一定是整个排序数组中最小的数。所以,只要找到最小的那个数,然后把前面的数全部按顺序加到后面,最后再将前面的数删除就可以了。

代码

代码语言:javascript
复制
public class Solution {
    /**
     * @param nums: The rotated sorted array
     * @return: void
     */
    public void recoverRotatedSortedArray(ArrayList<Integer> nums) {
        // write your code
        int temp = nums.get(0);
        int i;
        for( i = 0;i<nums.size();i++){
            if(nums.get(i)<temp)//找到最小的数
                break;
        }
        if(i!=nums.size()){
        for(int j=0 ; j<i;j++)
           nums.add(nums.get(j));
        nums.subList(0, i).clear();
        }
    }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016.12.01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 分析
  • 代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档