设为首页 加入收藏

TOP

编程算法 - 圆圈中最后剩下的数字(递推公式) 代码(C++)
2015-07-20 18:07:11 来源: 作者: 【 】 浏览:2
Tags:编程 算法 圆圈 最后 剩下 数字 公式 代码

圆圈中最后剩下的数字(递推公式) 代码(C++)

?

?

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

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

?

可以推导出约瑟夫环的递推公式, 使用循环进行求解, 时间复杂度O(n), 空间复杂度O(1).

?

代码:

?

/*
 * main.cpp
 *
 *  Created on: 2014.7.12
 *      Author: spike
 */

#include 
  
   
#include 
   
     #include 
    
      #include 
     
       using namespace std; int LastRemaining(size_t n, size_t m) { if (n<1 || m<1) return -1; int last = 0; for (size_t i=2; i<=n; ++i) { last = (last+m)%i; } return last; } int main(void) { int result = LastRemaining(5, 3); printf(result = %d , result); return 0; }
     
    
   
  

输出:

?

?

result = 3


?

?

?

?

/

?

?

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇编程算法 - 求1+2+...+n(函数继承.. 下一篇UVA - 11419 SAM I AM

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: