java使用List模拟环形链表

孩子们的游戏(圆圈中最后剩下的数)

http://www.nowcoder.com/questionTerminal/f78a359491e64a50bce2d89cff857eb6

java中直接使用一个list来模拟,并使用一个索引cur类指向删除的位置,当cur的值为list的size,就让cur到头位置。

mport java.util.*;
public class Solution {
    public int LastRemaining_Solution(int n, int m) {
        if(n<1||m<1){
            return -1;
        }
        List<Integer> list = new ArrayList<>();
        //构建list
        for(int i = 0;i<n;i++){
            list.add(i);
        }
        int cur = -1;
        while(list.size()>1){
            for(int i = 0;i<m;i++){
                cur++;
                if(cur == list.size()){
                    cur = 0;
                }
            }
            list.remove(cur);
            cur--;//cur--的原因,因为新的list中cur指向了下一个元素,为了保证移动m个准确性,所以cur向前移动一位。
        }
        return list.get(0);
    }
}
全部评论
ArrayList基于动态数组,它的删除性能并不好,如果要使用模拟法的话,用LinkedList效率更高吧(因为是基于双向链表);
3 回复 分享
发布于 2019-11-05 17:03
while(n>1){ cur = (cur+m-1)%n; list.remove(cur); n--; }
1 回复 分享
发布于 2020-12-25 21:09
请问(cur == list.size()) cur=0;什么意思啊
点赞 回复 分享
发布于 2021-06-27 23:02
并不需要双向链表,用普通单向链表就行,只需要维护一个前置指针用于删除即可.
点赞 回复 分享
发布于 2020-06-26 11:22

相关推荐

在笔试的柠檬精很想去...:兄弟们,你们这个大厂,中厂,小厂怎么定义的 初来驾到,别笑话我,只要能学到本事,不管大厂小厂都可以,但是别进到黑厂就行
找实习记录
点赞 评论 收藏
分享
评论
42
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务