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

相关推荐

05-19 15:21
已编辑
门头沟学院 Java
白火同学:你才沟通了200,说实话,北上广深杭这里面你连一座城市的互联网公司都没投满呢,更别说还有各种准一线二线城市了。等你沟通突破了三位数,还没结果再考虑转行的事吧。
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-03 17:30
点赞 评论 收藏
分享
评论
42
1
分享

创作者周榜

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