一亩三分地

 找回密码 注册账号

扫描二维码登录本站

BBS
指尖新闻
Offer多多
Salarytics
Learn
Who's Hiring?
疫情动态
Instant
客户端
微信公众号
扫码关注公众号
留学申请公众号
扫码关注留学申请公众号
Youtube频道
留学博客
关于我们
查看: 194|回复: 0
收起左侧

[学Java/C#] 求解LeetCode 189 的 in-place解法

[复制链接] |试试Instant~ |学java/c#, 刷题
我的人缘0

分享帖子到朋友圈
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   73% (215)
 
 
26% (78)    👎
189. Rotate Array
https://leetcode.com/problems/rotate-array/

不太理解,为啥这个start也要循环?  我的理解是,从start=0开始,就一撸到底了,为啥要这么写。

此外,大家有推荐的更好的in-place的写法吗? 我觉得我这个代码有点绕啊。。。

代码如下,




class Solution {

    /** Using Cyclic Replacements | no extra space  **/

    public void rotate(int[] nums, int k) {

            /** 1. 對 k 取模 **/
            k = k % nums.length;

            /** 2. 數目  **/
            int count = 0;

            /** 3. 只要count没超过总长度。问题: start什么时候会++ **/
            for (int start = 0; count < nums.length; start++) {

                        /** ~1 預留當前位置  **/
                        int current = start;

                        /** ~2 拿到原始位置的值  **/
                        int prev = nums[start];

                        do {
                                        int next = (current + k) % nums.length; // 获取下一坐标的位置   
                                        int temp = nums[next];  // 获取下一坐标对应的值

                                        nums[next] = prev;  // 更新下一坐标的值

                                        count++;  // 更新完后,count加一

                                        prev = temp;  // 把 "下一坐标对应的值(存在于temp)", 给prev

                                        current = next;  // 更新当前位置,为"下一坐标对应位置"

                        } while (start != current);
            }
    }
}



本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册账号

x

上一篇:CS相关知识交流 - 学生向
下一篇:动态规划DP系列 -完全背包问题 空间时间最优解
您需要登录后才可以回帖 登录 | 注册账号

本版积分规则

隐私提醒:
■为防止被骚扰甚至人肉,不要公开留微信等联系方式,请以论坛私信方式发送。
■特定版块可以超级匿名:https://pay.1point3acres.com/tools/thread
■其他版块匿名方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

手机版|||一亩三分地

GMT+8, 2020-5-28 05:00

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表