zoukankan      html  css  js  c++  java
  • 编程算法

    圆圈中最后剩下的数字(循环链表) 代码(C++)


    本文地址: http://blog.csdn.net/caroline_wendy


    题目: 0,1...,n-1这n个数字排成一个圆圈, 从数字0開始每次从这个圆圈里删除第m个数字.

    求出这个圆圈里最后剩下的数字.


    使用循环链表, 依次遍历删除, 时间复杂度O(mn), 空间复杂度O(n).


    代码:

    /*
     * main.cpp
     *
     *  Created on: 2014.7.13
     *      Author: Spike
     */
    
    #include <iostream>
    #include <list>
    
    using namespace std;
    
    int LastRemaining (size_t n, size_t m) {
    	if (n<1 || m<1)
    		return -1;
    	list<size_t> numbers;
    	for(size_t i=0; i<n; ++i)
    		numbers.push_back(i);
    
    	list<size_t>::iterator current = numbers.begin();
    	while (numbers.size() > 1) {
    		for (size_t i=1; i<m; ++i) {
    			current++;
    			if (current == numbers.end())
    				current = numbers.begin();
    		}
    
    		list<size_t>::iterator next = ++current; //指向下一个
    		if (next == numbers.end())
    			next = numbers.begin();
    		--current;
    		numbers.erase(current);
    		current = next;
    	}
    	return *(current);
    }
    
    int main(void)
    {
        int result = LastRemaining(5, 3);
        std::cout << "result = " << result << std::endl;
        return 0;
    }
    
    
    

    输出:

    result = 3
    




  • 相关阅读:
    夜半饮酒
    邀你到成都来
    成都,我的天堂
    真不想松开你的手
    创业,你懂如何求人办事么?
    只要你愿意
    【五月的歌】重振山河
    成都,我爱你
    就算忘了自己也忘不了你
    假如
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4492222.html
Copyright © 2011-2022 走看看